30 天 精通 Git 版 本 控 管 


来 源 : https:Wgithub.com/doggy8088/Learn-Git- 
in-30-dqaySs/tree/masterzh-tw 


第 01 大 : 认识 Git 唉 本 控 管 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/01.md 


笔者 使 用 Subversion (SVN) 已 经 将 近 10 年 ， 和 从 来 
都 不 恤 得 有 任何 必要 转换 至 其 他 版 本 控 管 平台 ， 直 
到 前 伙 年 因应 才 端 化 的 改 弧 ， 慢 慢 半 入 TFS 版 本 控 
管 (TFS Service)， 转 换 的 过 程 迁 算 顺 利 ， 只 因为 
SVN 和 与 TFS 的 版 本 控 管 概念 相近 ， 都 属於 集中 式 
版 本 控 管 系统 。 这 类 集中 式 版 本 控 管 系统 ， 使 用 上 
简单 、 直 澳 且 容易 进行 权限 控 管 ， 褒 真 的 ， 在 大 部 
分 的 开发 情境 下 ，Subversion 或 TFS 已 经 相当 足 
约 ， 那 又 是 甚 契 机 或 是 需求 ， 迫 使 我 们 一 定 要 转 
换 到 Git 版 本 控 管 呢 ? 我 相信 “， 不 同人 探 用 Git 一 
定 有 他 的 理由 ， 有 些 人 觉得 好 玩 、 有 些 人 澳 得 新 
鲜 、 有 些 人 澳 得 功能 强大 ， 扰 论 如 何 ， 只 要 这 个 理 
由 能 络 支 持 你 去 主动 认识 一 个 陌生 技术 ， 都 是 好 
的 ， 本 篇 文章 除了 带 大 家 认识 Git 版 本 控 管 机 制 

外 ， 也 会 说 褒 我 想 转 换 到 Git 的 理由 。 


文章 目的 


在 软体 开发 领域 ， 对 原始 码 进 行 版 本 控 管 是 非常 重 
要 的 一 件 事 ， 有 别 於 Subversion 或 TFVC (Team 
Foundation Version Control) 这 类 集中 式 版 本 控 管 
系统 ，Git 是 一 套 分 散 式 版 本 控 管 系统 (DVCS; 
Distributed Version Control System)， 范 带 来 许多 
版 本 控 管 上 的 各 种 优势 与 解决 传统 集中 式 版 本 控 管 
的 缺失 ， 例 如 支援 本 地 操作 、 估 份 容易 、 功 能 强大 
且 弹 性 的 分 支 与 合 儒 等 等 。 不 过 ， 由 於 Git 版 本 控 
管 无 论 在 版 控 届 念 刁 工具 使 用 上 ， 都 与 传统 集中 式 
版 控 工 具 差 星 甚大 ， 因 此 造成 了 不 小 的 学 习 和 门槛 。 


只 然 说 本 次 文章 的 主题 是 30 天 精通 Git 版 本 控 
管 ， ， 不 过 ， 褒 实在 的 ， 还 臭 有 点 言 过 其 丧 了 ， 
为 Git 博大 精深 ， 有 非常 多 细节 可 以 探究 ,如 果真 
的 要 应 用 在 工作 上 ， 学 几 天 可 以 真正 上 手 呢 ? 每 天 
学 一 点 ， 右 续 学 习 30 天 ， 似 乎 是 个 合理 的 数字 (或 
太 多 ?)， 如 果 有 一 个 工具 大 家 都 要 用 ， 而 且 要 立刻 
上 和 手 的 工具 ， 如 果 学 30 天 都 迁 不 知道 怎么 活用 ， 
那 这 学 习 自 橙 也 大 高 了 些 。 因 此 我 想 ， 这 个 系列 的 
文章 ， 主 要 还 是 专注 於 " 如 何在 30 天 内 学 会 Git 版 
本 控 管 ， 而 且 必 须要 能 熟练 的 应 用 在 实务 开发 工作 
上 ,4 ， 这 才 是 本 系列 的 真正 目的 ， 那 些 繁 玉 的 细 


和 节 ， 我 不 会 特别 强调 ， 但 总 是 有 些 重要 的 概念 与 细 
和 节 还 是 不 能 错过 ， 我 会 当 试 在 每 一 个 主题 中 提 到 一 
部 份 ， 一 有 机 会 就 会 深入 探讨 ， 和 希望 大 家 可 以 透 过 
做 中 学 ， 深 刻 体 会 Git 版 本 控 管 的 强大 魅力 。 


转换 的 奖 机 


这 继 个 月 ， 公 司 因 为 有 个 大 型 专案 ， 参 与 开发 人 数 
超过 12 人 ， 最 后 大 家 决议 揉 用 Git 作 入 本 次 专案 的 
版 本 控 管 机 制 ， 与 其 褒 我 们 揉 用 了 Git 版 本 控 管 ， 
其 实 真正 探 用 的 原因 是 “我们 跑 择 使 用 GitHub 沼 
成 我 们 的 版 控 平 台 ， ， 原 因 就 是 GitHub 平台 实在 
整合 得 太 好 ， 完 整 的 Git 版 控 支 援 、 议 题 追 跳 与 管 
理 、 线 上 Wiki 文件 管理 、 友 善 的 原始 码 审 核 (Code 
Review) 介 面 。 这 些 特性 ， 都 能 有 效 协 助 我们 在 多 
人 功 同 开发 的 过 程 中 ， 沽 少 转 队 沟通 的 问题 。 


交 表 始 接触 Git 说 实在 挺 平 天 的 ， 因 为 Git 版 本 控 
管 的 观念 ， 实 在 与 Subversion 差 太 多 ， 没 有 办 法 很 
直 澳 的 去 体会 其 差 虹 ， 就 算 给 了 你 GUI 图 形 化 工具 
介面 ， 你 也 不 见得 就 会 使 用 。 你 知道 的 ， 一 个 强大 
又 好 用 的 工具 在 你 手 上 ， 销 误 的 使 用 方式 , 比 
-不 会 用 , 还 可 怕 ! 说 穿 了 ， 就 是 你 必须 先 建立 一 
套 思 维 模 式 (Mindsel ， 了解 Git 的 有 运 作 原 理 ， 然 后 


再 上 手 使 用 Git 相关 工具 (无 论 是 指令 列 工 具 或 图 形 
化 介面 工具 )， 才 是 正 途 ! 


学 避 的 方法 


我 在 刚 学 习 Git 的 时 候 ， 看 了 好 绑 本 书 (其 实 是 挑 重 
时 看 )， 也 看 了 许多 线 上 的 文章 与 简报 ， 甚 至 还 看 了 
好 几 部 教学 影片 ， 看 著 看 著 ， 确 实 可 以 学 会 如 何 使 
用 Git 工具 ， 我 觉得 普 不 会 太 过 购 深 。 不 过 ，Git 的 
中 令 与 参数 非常 多 ， 完 全 超出 大 脑 能 记 屋 的 范围 ， 
除非 每 天 使 用 ， 否 则 哪 有 可 能 一 天 到 晚 打 指令 进行 
版 控 ， 如 果 每 次 要 使 用 Git 指令 都 要 查 书 的 话 ， 那 
这 也 大 没 效 率 了 点 ， 当 下 的 我 就 直 几 地 认为 ， 学 习 
Git 最 终 冰 是 要 回电 到 好 用 的 GUI 工具 ， 否 则 这 东 
四 在 图 队 中 可 能 个 容易 推广 。 


再 者 ， 因 为 Git 是 属於 "分散 式 版 本 控 管 ,机制 ， 
当 并 发 人 数 开 始 释 多 ， 版 本 库 又 开始 变 成 一 人 一 份 
时 ， 在 第 一 次 进行 多 人 分 支 与 合 供 的 过 程 时 ， 大 家 
都 饮 受 熟 获 ， 而 且 持 续 一 段 不 短 的 时 间 。 只 然 公 司 
内 部 有 先进 行 技术 分 享 ， 不 过 由 於 大 家 都 是 第 一 次 
学 ， 那 些 Git 的 抽象 概念 ， 还 没 办 法 深 植 人 心 ， 只 
能 基 於 Git 的 使 用 方法 进行 分 享 ， 例 如 工具 怎 庆 
用 、 有 哪些 昔 用 的 指令 、 甚 庆 特 殊 的 情况 下 应 该 下 


甚 称 指令 ， 诸 如 此 类 的 。 过 程 中 就 算 说 出 了 复杂 的 
原理 ， 由 於 大 家 震 於 Git 的 认 知 还 很 模糊 ， 不 同人 
对 Git 版 控 方 式 的 理解 也 不 必 相 同 ， 所 吸收 到 的 知 
识 与 概念 ， 也 不 一 定 一致 。 所 以 ， 只 然 上 完 课 了 ， 
大 家 还 是 需要 好 央 天 的 时 间 不 断 磨 合 ， 相 互 讨论 ， 
互相 解决 问题 ， 如 果 你 只 有 一 人 使 用 Git 的 话 ， 确 
实 不 容易 感受 Git 带 来 的 好 不， 也 恐怕 不 容易 坚持 
下 去 : 


所 以 ， 我 认为 ， 要 学 好 Git 版 本 控 管 ， 若 先知 道 以 
下 绑 点 ， 也 许 比较 容易 学 会 : 


。 先 提 有 Git 基础 观念 ， 透 过 下 指令 的 方式 学 习 
是 最 快 的 方式 ， 不 要 跳 过 这 一 段 

。 找 多 一 点 人 跟 你 一 起 学 Git 版 本 控 管 ， 最 好 能 
直接 用 在 实务 的 开发 工作 上 

。 转 队 中 最 好 要 有 绑 个 先 中 部队， 可 以 多 学 一 点 
Git 观念 ， 好 分 享 给 其 他 人 ， 或 有 人 卡 关 时 ， 
能 通 时 提供 协助 

。 了 解 Git 属於 "分散 式 版 本 控 管 ， ， 每 个 人 都 
有 一 份 完 整 的 储存 康 (Repository)， 所 以 必须 
经 常 合 侨 档 案 

。 使 用 Git 的 时 候 ， 分 支 与 合 供 是 常态 ， 但 只 要 
有 合作， 就 会 有 征 突 ， 要 学 会 如 何 解 决 种 突 


认识 Git 唉 本 控 管 


Git 的 出 现 ， 来 自 於 Linux 之 父 "Linus Torvalds" 开 
发 Linux kernel 的 时 候 ， 因 为 早期 的 版 本 控制 方法 
非常 没有 效率 ， 属 集中 式 控 管 ， 当 Linux kernel 这 
类 复 订 又 廉 大 的 专案 在 进行 版 本 控 管 时 ， 出 现 了 许 
多 问题 。 最 早期 Linux kernel 探 用 BitKeeper 进行 
版 本 控 管 ， 但 后 来 Linus Torvalds 基 於 BitKeeper 
与 Monotone 的 使 用 经 验 ， 设 计 出 更 棒 的 Git 版 控 
系统 。 原 先 Git 只 被 设计 成 一 个 低 障 的 版 控 工 具 ， 
用 来 当做 其 他 版 控 系统 (SCM) 的 操作 工具 ， 和 后 来 才 
渐渐 演 释 成 一 套 完 整 的 版 本 控制 系统 。 


有 趣 的 是 ，Linus Torvalds 改 揉 Git 进行 版 本 控 管 
初期 ， 由 於 Git 太 过 复杂 ， 许 多 版 控 观 念 跟 以 往 差 
畦 太 大 ， 也 受到 世界 各 地 开放 原始 码 社 群 的 反对 ， 
但 经 过 绑 年 的 努力 与 发 展 ， 操 作 Git 的 相关 工具 也 
越 来 越 成 熟 ， 才 渐渐 平手 反 针 的 压力 ， 和 从 2013 年 
的 市 场 调查 看 来 ， 全 世界 已 有 30% 的 开放 原始 码 专 
案 改 探 Git 进行 版 本 控 管 ， 这 是 个 非常 敬 人 的 市 占 
率 ， 意 谓 著 Git 绝对 有 其 入 灶 之 处 ， 不 好 好 研究 一 
番 还 不 行 呢 ! 


讲 到 Git 的 架构 ， 完 全 是 基 於 Linus Torvalds 在 维 


访 Linux kernel 这 个 大 型 专案 时 得 到 的 经 验 ， 以 及 
他 本 身 在 档案 系统 优化 方面 的 沁 富 经 验 进 行 设 计 ， 
也 因为 这 样 ，Git 包含 了 以 下 绑 个 重要 的 设计 : 


。 验 力 文 援 非 线性 开发 模式 (分 散 陈 开发 模 卫 ) 


O Git 扩 有 快速 的 分 支 与 合 供 机 制 ， 还 包括 
图 形 化 的 工具 显示 版 本 变更 的 历史 路 径 。 

O Git 非常 强调 分 支 与 合 伴 ， 所 以 版 本 控 管 
的 过 程 中 ， 你 会 不 断 的 在 执行 分 支 与 合 供 
动作 。 

O Git 的 分 支 机 制 非常 轻 量 ， 没 有 负担 ， 
一 次 的 分 支 只 是 某 个 commit 的 参考 指标 
而 已 

。 分 散 式 开发 模型 


O 参与 Git 开发 的 每 个 人 ， 都 将 所 有 完整 的 
开发 历史 纪 色 。 

O 〇 当 并 发 人 员 第 一 次 将 Git 版 本 库 复 揭 
(clone) 下 来 后 ， 完 全 等 同 於 这 份 Git 版 本 
库 的 “完整 备份 ， 。 

O 整个 版 本 库 中 所 有 释 更 过 的 档案 与 历史 纪 
朱 ， 通 通 都 会 储存 在 本 机 储存 库 (local 


repository)。 


。 相 容 於 现 有 作业 系统 


O Git 版 本 库 其 实 就 只 是 一 个 资料 夹 而 已 ， 
资料 来 中 有 许多 相关 的 设 定 档 与 各 种 blob 
物件 档案 而 已 。 

O Git 版 本 库 可 以 用 任何 方式 发 布 ， 所 以 你 
用 HTTP, FTP, rsync, SSH 甚至 於 用 Git 
protocol 都 可 以 当成 存 取 Git 版 本 库 的 媒 
介 ， 相 容 性 极 高 。 

。 有 效率 的 处 理 大 型 专案 


〇 由 於 完整 的 版 本 麻 会 复 抽 (clone) 一 份 在 本 
机 ， 该 版 本 库 包 含 完 整 的 档案 与 版 本 继 
纪 从 ， 所 以 针对 版 本 控 管 中 的 各 种 档案 操 
作 速 度 ， 将 会 比 直 接 和 从 下端 存 取 来 的 快 上 
百倍 之 多 。 

O 这 也 代表 著 ，Git 版 本 控 管 不 会 因为 专案 
越 来 越 大 、 档 案 越 来 越 多 ， 而 导致 速度 释 
慢 。 


。 历史 纪 公 保 访 


O gGit 版 控 的 过 程 ， 每 次 commit 都 会 产生 
一 组 hash id 编号 ， 而 且 每 个 版 本 在 变化 


的 过 程 都 会 参考 到 这 个 hash id， 只 要 


hash id 扰 法 比 对 的 上 ，Git 就 会 无 法 有 运 
作 ， 所 以 当 专 案 越 来 越 大 ， 版 本 库 复 秽 
(clone) 的 越 来 越 多 份 ， 你 秋平 扰 法 埠 改 档 
案 的 内 容 或 版 本 纪 凶 。 

O 〇 请 记得 : 每 个 人 都 有 一 份 完 整 的 版 本 库 ， 
你 改 了 原始 的 那 份 ， 所 有 人 的 版 本 库 就 无 
法 再 合 供 回 原本 的 版 本 库 了 ， 所 以 你 继 乎 
不 可 能 任意 窟 改版 本 纪 销 。 

。 以 工具 集 为 主 的 设计 (Toolkitbased design) 


O Git 被 设计 成 一 个 一 个 的 工具 软 仙 ( 指 令 列 
工具 )， 你 可 以 很 轻易 的 组 合 不 同 工 具 的 
使 用 ， 使 用 上 非 弟 弹性 。 

。 弹性 的 合 儒 策 略 (Pluggable merge strategies) 


O Git 有 一 个 扒 有 良好 设计 的 “不 完整 合 供 
(incomplete merge)， 机 制 ， 以 及 多 种 可 
以 完成 合 供 的 演算 法 ， 半 在 最 人 后 告知 使 用 
者 为 何 级 法 自动 完成 合 伴 ， 或 通知 你 需要 
手动 进行 合 儒 动 作 。 

。 被动 的 垃圾 回收 机 制 


〇 在 使 用 Git 的 时 候 ， 若 想 要 中 断 目前 的 操 
作 或 回复 上 一 个 操作 ， 都 是 可 以 的 ， 你 完 


全 可 以 不 必 担 心 可 能 有 其 中 一 个 指令 
错 ， 或 指令 执行 到 一 半 当 机 等 问题 。 

O Git 的 垃圾 回收 机 制 ， 其 实 就 是 那些 残留 
在 档案 系统 中 的 无 用 档案 ， 这 个 垃圾 回收 
机 制 只 会 在 这 些 扰 用 的 物件 累积 一 段 时 间 
后 自动 执行 ， 或 你 也 可 以 自行 下 过 指 令 清 
空 它 。 例 如 : git gc --prune 

。 定 期 的 封装 物件 


O 我 们 在 Git 中 提 到 的 "物件 "其实 融 是 代表 
版 本 库 中 的 一 个 档案 。 而 在 版 本 暴动 的 过 
程 中 ， 专 案 中 的 程式 码 或 其 他 档案 会 被 更 
新 ， 每 次 更 新 时 ， 只 要 档案 内 容 不 一 样 ， 
就 会 建立 一 个 新 的 "物件 "， 这 些 不 同 内 容 
的 档案 全 部 都 会 保留 下 来 。 

O 你 应 该 可 以 想像 ， 当 一 个 专案 越 来 越 大 、 
版 本 越 来 越 多 时 ， 过 个 物件 会 越 来 越 多 ， 
只 然 每 个 档案 都 可 以 各 自 灰 缩 让 档案 释 
小 ， 不 过 过 多 的 档案 迁 是 会 档案 存 取 释 得 
越 来 越 没 效率 。 因 此 Git 的 设计 有 个 机 制 
可 以 将 一 群 老 苗 的 "物件 " 自动 封装 进 一 个 

封 对 棉 (packfile) 中 ， 以 改善 榴 案 存 取 效 

O 〇 那些 新 增 的 档案 迁 是 会 以 单一 档案 的 方式 


存在 著 ， 也 代表 一 个 Git 版 本 库 中 的 " 档 
案 " 就 是 一 个 Git "物件 "， 但 每 隔 一 段 时 间 
就 会 需要 重新 封装 (repacking)。 

O 照 理 说 Git 会 自动 执行 重新 封装 等 动作 ， 
但 你 依然 可 以 自行 下 过 指令 执行 。 例 如 : 
git gc 

〇 O 如 果 你 要 检查 Git 维护 的 档案 系统 是 否 完 
整 ， 可 以 执行 以 下 指令 : git fsck 


关於 Git 的 分 散 式 版 控 系 统 ， 我 再 重申 绑 件 事 : 


。Git 完全 不 需要 伺服 器 端的 支援 就 可 以 还 作 版 
本 控制 ， 因 为 每 个 人 都 有 一 份 完 整 的 储存 库 副 
本 。 

。 因为 每 个 人 都 有 一 份 完整 的 储存 库 副 本 ， 所 以 
每 次 提交 版 本 变更 时 ， 都 俊 提 交 到 本 地 的 储存 
库 而 已 ， 因 此 提交 速度 非常 快 ， 也 个 用 网 路 过 
线 ， 可 大 幅 和 节省 开发 时 间 。 

。 由 於 每 个 人 都 有 一 份 完 整 的 储存 库 副 本 ， 代 表 
著 在 使 用 Git 版 本 控 管 时 ， 没 有 所 谓 的 权限 
控 管 , 这 件 事 ， 每 个 成 员 都 能 把 储存 库 复 秽 
(clone) 回 来 ， 也 都 可 以 在 本 地 提交 变更 ， 没 有 
任何 权限 可 以 限制 。 使 用 Git 时 ， 唯 一 能 设 定 
的 权限 是 ， 你 有 没有 权利 存 取 上 层 储存 库 


(upstream repository) 或 下 端 储存 库 (remote 
repository) 的 权限 。 

。 如 果 需 要 跟 别人 交换 释 更 后 的 版 本 ， 随 时 可 以 
透 遇 ' 合 伴 , 的 方式 进行 ，Git 所 有 非常 强悍 
的 合 供 追 跳 (merge tracing ) 能 
要 合 伴 多 人 的 版 本 ， 你 只 要 有 存 取 共 用 储存 库 
(shared repository) 的 权限 或 管道 即 可 。 例 
如 : 在 同一 台 伺 服 器 上 可 以 透 过 资料 夹 权限 进 
行 共 用 ， 或 透 遇 SSH 踪 端 存 取 另 一 台 僻 服 器 
的 Git 储存 库 ， 也 可 以 透 过 Web 僻 服 器 等 方 
式 来 共用 Git 储存 库 。 


今 今日 小 颖 


今 知 看 不 大 懂 Git 的 设计 
里 念 没 关 傈 ， 你 可 以 用 一 段 时 间 之 后 再 回来 看 这 篇 
， 或 许 会 有 更 深 一 层 的 体会 。 


。 Git (Software) - Wikipedia, the free 
encyclopedia 

。 Pro Git Book 

。Git Magic - 繁体 中 文 版 

。 简介 Git 及 使 用 

。 版 本 控制 - 维基 百科 ， 自 由 的 百科 全 韦 


。 HOME 

。 回 目 录 

。 下 一 天 : 在 Windows 平台 必 装 的 三 套 Git 工 
具 


第 02 天 :在 Windows 平台 
必 装 的 三 套 Git 工具 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterzh-tw/02.md 


要 开始 使 用 Git 版 本 控 管 ， 首 先 要 安装 送 当 的 Git 

工具 ， 这 个 系列 的 文章 主要 还 是 以 Windows 平台 

为 主 ， 这 篇 文章 将 会 介绍 三 套 我 们 最 常用 的 Git 版 
控 工 具 ， 范 介绍 这 继 套 工具 之 问 的 轩 同 之 处 ， 还 有 
在 何 时 要 用 甚 庶 工 具 。 


第 1 套 : Gitfor Windows 


这 是 一 个 可 以 在 命令 提示 字 元 (Command Prompt) 
下 执行 的 一 套 指 令 列 工具 ， 目 前 市 面 上 所 有 Git 的 
GUI 工具 ， 其 实 骨 子 壬 都 是 执行 这 些 较 为 底层 的 
Git 工具 ， 所 以 是 一 套 必 人 备 的 Git 管理 工具 ， 非 装 不 


先 过 到 http:/msysgit.github.io/ 官网 ， 淮 人 备 下 
载 安装 档 


吉 GitforWindows 关 


: 忆 C 口 msysgit.github.io 


Welcome to the home page of Git for Windows 
Giis a Powerful version control system aiming to be the fastest decentralized source code management 


tool on this planet 


Having its root in the Linux development community, Git used to be quite dependent on POSIX features 
usually only Provided by Unix-style Operating Systems. Thanks to the efforts of a few contributors. this 
projact succeeded in providing an almost feature-complete fork of Git on Windows_Being solely driven by 


volunteers in their spare time, itis nevertheless quite stable FE 
Downleads 


How to staft 


， Startmenu 
。 Desktop shortcut Links: 
。 QuickLaunch icon 。FAQ 
。 Explorer context menu 。 Homepage 


Something does not work? Hawe a look at the Community and how to ReportFix Bugs， 


uild environment) 


不 管 哪个 版 本 ， 下 载 最 新 版 就 对 了 


价 Downloads - msysgit-G x 


所 C | https: /code. google. comyVpPVmsysgitydownloadsylist?q=full+installe 


由 msysgit 


Git for Windows 


Project Home | Downloads | Wiki ”Source 


Search [ Current downloads 回 for fullinstaller oficial git |Search 


2 Filename Summary + Labels Y 
贺 Git-18.3-preyiew20130601exe Full installer for oficial Git for Windows 1.8.3 |Fesiured 6eis 


汉 1 Downioad 


[二 ] Git-18.0-preview20121022.exe ”Fullinstaller for ofiicial Git for Windows 1.8.0 Beia 


2-preview20130201.exe Full installer for oficial Git for Windows 1.8.1.2 Betis 


直接 点 本人 下 载 的 档案 进行 安装 


青 中 


令 Git-1.8.3-Preview2..-.exe 从 


Git-1.8.3-preview20130601.exe 


今 Git Setup 人 


Welcome to the Git Setup Wizard 


This will install Git version 1.8,3-preview20130601 on your 
computer， 


Itis recommended 让 at you dose a 引 other applications before 
continuing, 


Clid Next to continue, or Cancel to exit Setup， 
Next > S Cancel 


意 GPL 授权 休 款 


JInformation 
Please read the following importantinformation before continuing. 


When you are ready to continue with Setup, dick Next, 


httpy 几 msys 


Git Setup 


GNU General Public License 


Version 2, ]une 1991 
Copyright 〈Cc) 1959， 1991 Free Software Focundaticn ，Jnc， 
59 Tenmple Place - Suite 330，5oston NA 02111-1307。USA 


Eve 语 permitted to copy and 机 Stribute verbatim copi 
of this 1icense document， but changing 让 应 not allowe 


Preamble 


The licenses for most software are designed to take away Your 
freedom to share and change it By contrast, the GNU General Public 
1icense is intended tno_nuarantee vour freednm tn _ share and channe Y 


| 
<Badk | ENA | Cancel 


Git Setup 下 


Select Destination Location 
Where should Gitbe installed? 


县 Setup willinstall Gitinto the followina folder. 


To continue, didk Next, If you would like to select s different folder, dick Browse. 


Atleast 80.9 M6 of free disk space is required 


http 必 msy 


sgit,googlecode,corml 


<Bad | et> IN | cana 


。 玩 取 元 件 ， 建 议 取 消 勾 选 Windows Explorer 


integration 玩 项 ! 
( 因为 这 套 整合 工具 太 隅 春 ， 建 议 改 用 
TortoiseGit 工具 ) 


Select Components 
Which components should be installed? 


Select the components You want to install; dear the components you do not want to 
instal. Clid Next when you are ready to continue. 


扩 人 Advanced context menu (git<cheetah plugin) 
Associate .git* configuration files with the de 和 ult text editor 
[ 回 Associate .sh files to be run with Bash 


Current selection requires atjeast 80.3 MB of disk space. 
http;Wmsysait,googlecode;comi/ 


。 设 定 程式 集 名 称 ， 保 留 预 设 遗 项 即 可 


仿 Git Setup 


Select Start Menu Folder 
Where should Setup place ithe program's shortcuts? 


胡 
图 Setup will create the program's shortcuts in 由 e 和 llowing Start Menu folder， 
ER 


To continue, didc Next, 于 you would like to selecta different 和 lder, didk Browse, 


| Browse..， 
所 jpon'tecreate a Start Menu folder 
http;Jmsysgit,googlecode,corm/ 
<Bade | Next > .cancel | 


<Bad JU > 


。 这 壬 建议 导 择 愤 择 Run Git from the 
Windows Command Prompt 这 个 遗 项 
( 因为 Windows 使 用 者 大 多 不 熟 Bash 指令 令 ) 


令 Git Setup Se 


Adjusting Your PATH environment 
How would you like to use Git fom 由 e command liney? 


CD Use Git Bash only 
Thisis the most conservative dhoice 二 You are concerned about the stability 
of your system. Your PATH wil notbe modifed. 

二 ) Run Git from the Windows Command Prompt 


This option is considered safe and no conficts other tools are known. 
only Git will be added to your PATH. Use this option 和 fyou want to use Git 
fom 5 Cygwin Prompt (make sure to not have Cygwin's Gitinstalled). 


“Run Gitand included Unix tools from the Windows Command Prompt 


Both Git and its sccompanying Unix tocls will be added to your PATH 


Warning: This will override Windows tools like find.exe and 
soOrLexe. Seject this option oniy 芽 you understand the implications. 


http; 凡 msys 


t,googlecode cor 中 


<6ad | Next> Cancel 


。 换行 字 元 转换 ， 建 议 保留 预 设 遗 项 即 可 。 
令 Git Setup 一 D 配 到 


Configuring the line ending conversions 
How should Git treatline endings in text files? 


Git will convertLF to CRLF when 中 edking out text 和 les. When committing 
text files, CRLF will be converted to LF, For Coss-platform projects， 
this is 由 e recommended setting on Windows [core,autoalf is setto "rue?)， 


CC Checkout as-is, commit Unix-style line endings 


Git will not perform any conyversion when 中 edking out text files, When 
committing text fles, CRLF will be converted to LF, For aoss-platform projects， 
thisis 中 e recommended setting on Unix Ccore.autoalf is set to input])， 


CD Checkout as-is, commit as- 二 


Git will not perform any conversions when 中 edking out or committing 
text fles, Choosing this option is notrecommended for Goss-platform 
projects [fcore,autoalf is set to folse 1)， 


令 Git Setup - 呈 配 到 


JInstaiing 
Please wait while Setup instals Git on your computer, 


Extracting 和 es.., 
C:\WProgram Files (x85)\Gityibexecgit-core\gitTemotehttps.exe 


长 


| 仿 Git Setup -” 口 天 的 
Completing the Git Setup Wizard 
Setup has finished installing Git on your computer. The 
application maybe laundhed by selecting the installed icons， 
Chid Finish to exit Setup. 


EN 


。 安装 完成 后 ， 直 接 开 族 命令 提示 字 元 ， 就 可 以 
开始 使 用 


坦 和 程式、 资料 交 、 文 件 或 帝 荐 网 路 资源 的 名 稳 ，Windows 
会 自动 天 庚 


。 你 可 以 输入 sit --version 指令 查询 目前 工 
有 具 程式 的 版 本 


:N>9LIt 一 -uvuekhsion 


it ueksion 1.8.3-msyvsgit -日 


第 2 套 :GitHub for Windows 


没有 很 了 解 的 人 用 的 ， 用 简 泽 和 与 亲民 的 GUI 介面 ， 
企图 隐藏 Git 那些 难 懂 的 宙 念 与 指令 参数 。 只 然 
GitHub for Windows 工具 比 起 Git for Windows 亲 
和 许多 ， 但 对 Git 完全 没有 概念 的 人 来 说 ， 要 上 手 
GitHub for Windows 工具 可 能 也 不 是 件 容易 的 事 。 


GitHub for Windows 内 建 了 一 个 Git Shell 工 
具 ，, 这 工具 会 用 到 Git for Windows， 所 以 如 

果 你 没有 安装 Git for Windows 的 话 ， 也 将 扰 
法 使 用 GitHub for Windows 的 Git Shell 工具 


O 


这 套 工 具 可 以 才 你 完成 的 Git 版 控 工 作 已 经 释 多 
的 ， 至 少 基本 版 控 功 能 都 有 提供 ， 最 主要 有 以 下 能 
为 生 


。 Clone Repositories 


O 将 GitHub 上 面 的 储存 库 复 秽 回 来 (git 
clone) 
。 Browse History 


O 浏览 本 地 储存 库 的 版 本 奈 史 纪 针 


。 Commit Changes 


O 提交 释 更 到 本 地 储存 库 


。 Branch Code 


O 建立 与 管理 Git 分 支 ， 还 可 以 在 工作 目 销 
中 切换 分 支 


。 Share on GitHub.com 


O 与 GitHub 同步 释 

O 〇 O 这 里 "同步 ， (Sync) 的 意思 是 将 git pull 
与 git push 整合 在 一 起 

O GitHub for Windows 在 同步 的 时 候 ， 预 设 
是 使 用 rebase 方式 进行 合 供 。 


除 此 之 外 的 大 部 分 Git for Windows 能 做 的 事 ， 在 
GitHub for Windows 壬 面 都 不 能 做 ! 各 真 的 要 认 用 
在 较为 大 型 的 开发 专案 上 ， 可 能 要 考虑 看 看 是 否 送 


用 ， 但 如 果 是 给 非 软 体 并 发 人 员 来 说 ， 简 单 的 版 控 
工作 砍 该 非常 足 锣 。 


以 下 是 GitHub for Windows 安装 过 程 


。 先 连 到 http:/windows.github.comy/ 准 人 备 下 载 安 
装 档 


EL :| 
图 GiHubforwindows  x 
所 GD windows.github.com 


GitHub Windows 晤 dowmioadGhhub orwndoms 


Overview help release notes 用 Windows XP, Vista,7B8 


人 
local README.md 
ROSS t2/GitForDelphi 1 站 
中 libgit2 - the Git linkable library 
github t2/libgit2 业 CLONE ED3EED 
于 
libgit2-backends libgit2 sa portable, pure Cimplementation ofthe Git core metho 
linkable library with a solid API allowing you to write native speec 


名 github 
人 | 


Introducing GitHub for Windows 


Develop on Windows, share on GitHub。 


anylanguage with bindings， 


人 aone Repositories (OO) Browse History (OO commit changes ”人 GO) Branch code ”人 shareon itHub-c 


应 用 程式 安装 - 安全 性 警告 
您 要 安装 此 讨 用 程式 咕 ? 


名 帮 (N): 
GitHub 


从 (停留 在 下 画 的 字 审 上 即 可 查看 完 整 欧 域 ): 


github-windows.s3.amazonaws.com 
改行 者 (P): 
GitHub.Inc 


去 和 半 四 不 要 安 半 (D) 


验 然 过 此 来 读 线 胡 纺 路 的 放 用 程式 可 能 很 有 用 ， 但 是 它 全 岂可 塌 淄 您 的 系 纺 过 成 侮 害 * 如 果 您 不 售 
任 其 来 源 ， 则 请 勿 安 半 此 款 伯 ， 许 细 次 训 - 


。 刚 下载 GitHub for Windows 安装 档 的 时 候 可 
能 几 得 安装 档 很 小 ， 但 事实 上 真正 在 安装 的 时 
候 才 会 下 载 所 需 的 档案 ， 所 以 必须 保持 网 路 违 
线 


(096) 正在 安装 GitHub - 唱 
正在 安装 GitHub 地 
这 可 能 要 花 演 分 阔 的 时 间 。 在 安 半期 关 ,您 可 以 在 重 腾 上 淮 行 其 人 工作 - 


加 GitHub 


从 : github-windows.s3.amazonaws.com 


正在 下 载 : 343 KB / 39.8 MB 


取 潢 (O 


。 下 载 完 成 滞 ，GitHub for Windows 工具 会 直接 
被 并 艇 ， 站 进行 初始 设 定 工 作 


O 开 族 GitHub for Windows 的 第 一 步 就 是 
先 登 入 GitHub 帐户 (你 也 可 以 点 击 SKIP 
SETUP 跳 过 这 一 步 ) 


welcome 


connect configure repositories 


connect to github 


O 然后 他 会 要 求 你 先 设 定 好 user.name 与 
user.email 这 两 个 参数 ， 这 两 个 是 使 用 任 
何 Git 工具 最 重要 的 步 又 之 一 ， 没 有 设 定 
这 两 个 参数 是 完全 无 法 commit 任何 版 本 
的 。 人 备 广 : 这 两 个 参数 预 设 会 设 定 到 
Global config 之 中 ， 也 就 是 "C: 
\Users<user>.gitconfig" 这 个 档案 。 


welcome 


connect configure repositories 


configure git 
Wil 保 哥 


This will change your global 


CONTINUE SKIP 


从 


welcome 


| 


。 首次 使 用 如 果 有 成 功 登 入 GitHub 帐户 ， 
GitHub for Windows 会 自动 建立 一 组 SSH 
Key-Pair 在 c:\Users\<username>\.ssh 目 欠 
下 ， 这 可 以 训 你 在 日 后 同步, 本 地 与 让 端 储 
存 库 时 不 用 再 输入 帐号 密码 。 


GitHub for Windows 者 你 彦 生 的 SSH Key 预 
设 路 径 如 下 : 


〇 O CUsers&ltiusername>\ssh 
\github _ rsa 

〇 O CUsers&ltiusername>\ssh 
\github_rsa.pub 


SSH Key 的 签 章 的 部 分 也 会 在 登入 的 同时 上 传 
到 GitHub 网 站 ， 你 可 以 从 个 人 的 设 定 书 面 ( 
https:/github.com/settings/ssh ) 中 看 到 曾经 上 
传 过 的 SSH Key 签 章 : 


人 。 Explore Gist Blog Help 辕 doogysoss 上 马 六 时 


Account Settings 


Emails 


Applications 


。GitHub for Windows 装 好 之 后 ， 其 实 还 额外 才 
你 安装 了 一 个 Git Shell 工具 ， 这 预 设 是 一 个 
PowerShell 介面 的 操作 环境 ， 好 处 有 很 多 ， 之 
人 后 我 们 的 例子 也 会 画 量 使 用 Git Shell 来 进行 操 
人 


O 可 以 在 指令 列 使 用 ^ 符号 (在 命令 提示 字 
元 不 能 接 使 用 ^ 符号 ) 
O 可 以 在 Git 工作 目 杀 下 可 以 得 到 额外 的 提 
示 资 讯 (Prompt) 
。 不 过 使 用 Git Shell (PowerShelh 也 有 一 个 小 缺 
点 


〇 O 由 於 PowerShell 里 面 {}) 具有 特殊 意 
义 ， 所 以 若 你 的 git 参数 会 用 到 {) 符号 
的 话 ， 记 得 该 参数 的 前 后 要 加 上 ' 音 引号: 


第 3 套 : SourceTree 


这 套 是 由 ATLASSIAN 这 问 公 司 开 发 的 工具 ， 是 一 
套 非 常 专业 的 GUI 操作 工具 ， 不 仅 支 援 Git 版 本 控 
管 ， 同 时 也 支援 Mercurial 版 本 控 管 机 制 ， 这 两 套 
版 本 控 管 机 制 都 属於 分 散 式 版 本 控 管 的 分 类 ， 概 念 
上 也 十 分 相近 ， 所 以 可 以 整合 在 这 一 套 工 具 上 使 
用 。 


SourceTree 其 实 骨 子 里 也 是 透 遇 Git for 
Windows 工具 进行 版 本 操作 ， 如 果 你 没有 事 
先 安装 Git for Windows 的 话 ， 安 装 的 过 程 中 
他 也 会 提示 你 要 不 要 顺便 安装 起 来 。 


SourceTree 的 功能 相 较 於 GitHub for Windows 是 
强大 许多 ， 绑 乎 所 有 的 指令 列 功能 都 能 级 过 
SourceTree 的 GUI 介面 完成 ( 透 过 滑 鼠 操作 )， 不 过 
还 是 老话 一 句 ， 如 果 你 骑 Git 的 核心 宙 念 不 大 了 
解 ， 再 多 的 右键 导 单 对 你 来 说 等 同 於 白 纸 一 张 ， 一 
六 不 知道 特 样 操作 。 但 你 若 认真 的 了 解 Git 的 运作 
机 制 盖 宙 念 ， 使 用 SourceTree 绝对 能 鹏 事 半 功 


倍 ! 


以 下 是 SourceTree 安装 过 程 : 


。 先 建 到 http:/www.sourcetreeapp.comy/ 准备 下 


载 安装 档 


罗 国 四 
厅 目 


Atlassian 


曲 SourceTree 


Afree Git8 Mercurial client for Windqows or Mac， 


。 下 载 完 后 直接 执行 安装 ， 其 余 的 安装 步 县 就 直 


接 一 直 按 Mext 到 最 人 后， 然后 直接 开 族 


SourceTree 程式 


SourceTree Setup 


Welcome to SourceTree Setup 
Wizard 


The Setup Wizard will install SourceTree on your computer, 
Click Next to continue or Cancel to exit the Setup Wizard, 


Cancel 


久 SourceTree Setup 人 


Select Installation Folder 
Thisis the folder where SourceTree wil be installed， 


Toinstallin this folder, did Next". To install to a different folder, enter it below or dick 
"Browse 


advanced Installer 


四 SourceTree Setup 
Ready to Install 
The Setup Wizard is ready to begin the SourceTree installation 


Clidk Install to begin the installation， If you want to review or 中 ange any of your 
installation settings, did 6acdk，Clid Cancel to exit the wizard. 


adyanced Installer 


SourceTree Setup 


Completing the SourceTree 
Setup Wizard 


Clicd the Finish button to exit the Setup Wizard, 


yj Laund SourceTree 


Cance 


。 第 一 次 艇 动 SourceTree 时 ， 会 问 你 要 不 要 | 
便 安 装 Mercurial ,可 装 可 不 装 


SourceTree: Mercurial not found 


伟 芥 “We were not ableto locate a Mercurialinstallon your system 
”already. There are 3 ways we can deal with this: 


Download an embedded version of 
Mercurial for SourceTree alone to use. 


Browse to the location of Mercurial on your 
system (fwe missed 站 


Check again (should you wish to download 
内 and install a fullversion of Mercurial yourself 
right now) 


内 Idontwantto use Mercurial N 


第 一 次 使 用 SourceTree 时 , 跟 GitHub for 
Windows 一 样 ， 都 要 设 定 预 设 的 user.name 
与 user.email 这 两 个 参数 ， 不 过 ， 如 果 你 有 按 
照 本 文 步 又 安装 的 话 ， 这 一 步 应 该 不 用 特别 办 


入 ,因为 之 前 输入 的 参数 都 已 经 写 入 到 Git for 
Windows 的 Global 设 定 档 中 ， 这 旭 会 自动 被 
带 入 ， 你 直接 按 下 Next 即 可 。 


候 Welcome 


Atlassian 


/50urceTree 


Welcome to SourceTreel Let's get started_. 
Userinformation 


When you commit, use these details by default 
Full Name: Will 保 哥 


Email address myemail@example com 


You can set alternate details per repository using the Settings button in the 
tooclbarlater. 


| 
4 


Allow SourceTreeto modify your gloebal Git and Mercurial config files 
Configure automatic line ending handling by default (recommended) 


Iagreeto the SourceTree license agreement 


SlGsp Setup 


Previous 


。 这 个 步 灵 则 是 选择 通 沼 的 SSH Client， 这 是 略 


了 跟 这 端的 Git 储存 库 认 证 所 需要 的 工具 ， 遗 
用 预 设 值 即 可 。 


氏 


Welcome 


SSH Client Configuration 
二 Use PuTTY/ plink (recommended) 


The PuTITY suiteisa Windows-native implementation of SSH and isthe 
most friendly tc use. Ht has GUI interfaces for generating and 
manipulating keys, and an agent which sits in your system tray 
{pPageant)j. We stronghly recommend you use PuTTY for SSH on Windows. 


属 Use OpenSSH 


OpenSSH is a cross-platform SSH implementation designed prnimarily to 
be runvia Unix-compatible terminals. While SourceTree can supPort 
using OpenSSH, we actually recommend you convert any existing 
OpenSSH keys to PuTTY instead, because the experience is better and 
more native- 


开 you choose to use OpenSSH (and the only reason to do soisifyou 
have an extended .sshy/config that you don't want to convertto the 
PuTTY equivalent) you will see a terminal being launched at startup to 
provide ssh-agent capabilities ratherthan a system tray widget as with 
PuTTY (meaning you have to type your key passphrase everytime you 
start SourceTreej, and we also can only support authentication via keys 
with OpenSSH and not manual user/password combinations. 


Skip Setup 


接著 这 个 步 又 则 是 问 你 是 否 已 有 SSH Key 存 

在 ， 由 於 我 们 在 GitHub for Windows 已 经 产 

生 过 一 个 GitHub 专用 的 SSH Key， 所 以 你 也 
可 以 在 这 一 步 按 下 Yes 芷 跑 

取 c:\UsersN\<username>\.sshN\dqithub_rsa 


这 个 档案 (这 是 一 个 SSH 私密 金 欠 )。 


入 


只 然 
女装 


Load SSH Key? 


De you have an SSH keythat you'd liketo load now? 和 fnot you can click 
”No'and create onelaterifyou like-. 


SourceTree 是 免费 软体 ， 但 还 是 必须 在 
装 和 后 30 天 内 "免费 广 册 " 得 到 序号 和 后， 才能 


继续 使 用 。 


| Fie | Edit ”View ”Repository ”Actions Tools Help 
Clone/ New-_ Ctrl+N 6 [| ER EA 硬 
HH 
5 


Registration_ | 


SetupP Wizard _ S jin 


Exit SourceTree AIFF4 


。 立即 主 册 一 个 授权 


全 Registration 


Trial version expires in 30 days. f you like SourceTree, please 


办 register it's FREEI 


。 先 输入 Email 地 址 


久 Register SourceTree 


Please enteryour email address- 


Email address- | 后 汪汪 


Licenses managed by- MyAtlassian (Privacy Policy) 


EAIE 


。 然后 输入 一 些 个 人 基本 资料 与 设 定 一 


人 和 后 
即 可 这 册 完 成 


明 Register SourceTree 


Please enteryour registration details- 


Email address- |myemail@example co 
First Name- 
Last Name- 


Password- 
Confirm Password- 
Company- 


Country | Taiwan 


Licenses managed by: MyAtlassian (Privacy Policy) 


EN Cancel 

。 如 果 你 在 另外 一 台电 脑 也 安装 SourceTree 的 

话 ， 直 接 输 入 第 一 次 广 册 时 设 定 的 密码 即 可 自 
动 下 载 授权 档 进 行 广 册 


Pleaselog in to your existing my.atlassian.com account 


Email address- | 病 尖 肖 地 
Password- 【ITIXXIIIXIXIXXI 


Forgotten your password? 
Licenses managed by- MyAtlassian (Privacy Policy) 


虑 OK 避 Cancel 


。 主 册 成 功 


鳃 Registration 
Thank you forregistering SourceTreel 
0 “Registered to- 
Name: 
Emai| 顶 生 汪 @gmailcom 
[mporticense | [RegiSIECNOw= Fee | close 内 


。 在 使 用 SourceTree 的 时 候 ， 有 个 Open in 
Terminal 功能 ， 这 会 开 艇 一 个 类 似 Cygwin 的 
命令 提示 字 元 视窗 ， 让 你 直接 操作 git 命令 。 


5ile Edit View Repositon 下 cions ]| Tools Help 


全 清 @ Open-_ Shift+Ctrl+O 
Clone/7New Commit Checkdq 二 
Ctrl+AHt+T 
令 关 1 CN\Users | 
@ Rebase-| 包 develop | External Di Ctn+D 
Add Shi#t 司 
Remove Ctn+De 
Unstage fromindex ctqd+Shift+Minus 
Add/Remove Ctnl+Shift+AHt+plus | 
Stop Tracking 
J9nore 
Commit Selected-_ Ctnl+AK+C 
Discard Selected- Ctnl+Alt+R 
Continue Rebase 
Abort Rebase 
Abort Gra 必 
Log Selected-_ Ctnl+Alt+L 
Blame Selected-_- Ctnl+Alt+B 
CopPy 
Move. | 
T TITTTT 


第 4 套 : TortoiseGiit 


TODO 


今日 小 短 


今天 这 篇 急 细 靡 遗 的 介绍 三 套 在 Windows 底下 党 
用 且 功 能 强大 的 Git 版 控 工 具 ， 这 三 套 只 要 能 上 
手 ， 绝 对 能 约 大 幅 提升 Git 版 本 控 管 的 使 用 效率 ， 
绝对 值得 大 家 好 好 研究 研究 。 


不 过 ， 我 再 耳 提 面 命 一 次 ， 要 学 会 使 用 Git 的 GUI 
介面 工具 ， 一 定 要 先 所 有 完整 的 Git 版 控 概 念 ， 否 
则 真 的 很 难 圭 活 运 用 这 些 好 用 工具 。 


参考 壬 结 


。 Git for Windows 
GitHub for Windows 
Source Tree 


。 TortoiseGit 


。 前 一 天 : 认识 Git 版 本 控 管 
。 下 一 天 : 建立 储存 库 


第 03 天 : 建立 储存 库 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/03.md 


要 开始 使 用 Git 最 重要 的 就 是 要 先 有 一 份 Git 储存 
库 (Git Repository) 才 行 ， 但 是 ， 这 份 储存 订 从 哪 壬 
来 呢 ? 本 篇 文章 会 介绍 多 种 建立 储存 库 的 方式 。 


要 建立 储存 庆 ， 事 实 上 ， 你 有 很 多 跑 择 ， 例 如 : 


。 在 本 机 建立 本 地 的 储存 库 (local repository) 

。 在 本 机 建立 一 个 共用 的 储存 库 (shared 
repository) 

。 在 GitHub 或 其 他 Git 平台 建立 这 端的 储存 库 


(remote repository) 
无 论 如 何 ， 你 总 是 需要 一 个 储存 库 ， 我 们 分 别 说 明 
如 下 : 


在 本 机 建立 本 地 的 储存 库 (local 


repository) 


我 们 先 开 艇 GitHub for Windows 的 Git Shell 工 
具 ， 这 工具 其 实 是 个 Windows PowerShell 介面 ， 
但 外 排 了 一 些 Git 相关 的 环境 释 数 与 命令 提示 设 定 
(Command Prompt) : 


有 1 桌面 专用 的 sepe 
对 2 Git shell 


shell with Gi enebled 
5) 文 竹 


党 我 的 图 只 


蕉 5 Lync 2013 翅 胶 


最 近 的 项 目 
控制 台 (O) 
网 路 连 综 (N) 
印 表 机 (p) 


搜寻 (oO 
褒 明 及 支援 (中 


开启 后 ， 预 设 会 直接 进 


入 USERPROFEILESN\Documents\GitHub 资料 ， 这 


是 GitHub for Windows 的 预 设 专 案 根 目 朱 ， 也 就 是 
只 要 预 设 透 过 GitHub for Windows 从 GitHub 复 揭 
(clone) 下 来 的 专案 都 会 放 在 这 个 目 凶 。 


所 以 ， 我 们 可 以 直接 在 这 壬 建立 一 个 新 目 朱 ， 好 富 
成 我 们 的 “工作 目录 ，(working directory)， 我 们 可 
以 输入 指令 mkair sit-demo 把 目 录 建立 起 来 。 然 
后 再 用 cd gd9it-adqemo 进入 该 目 杀 。 


由 於 这 是 一 个 空 目录 ， 琵 不 包含 任何 Git 储存 库 ， 
这 时 我 们 要 建立 储存 库 ， 就 可 以 用 sit init 指令 
把 储存 库 给 建立 起 来 ， 预 设 储 存 库 会 放 在 工作 目 针 
下 的 村 计 七 目 色 下 。 


完整 的 操作 步 县 如 下 图 示 : 


| 嫩 posh~git ~ git-demo [maste] 


建立 完成 后 ， 你 在 Git Shell 的 命令 提示 符号 中 ， 应 
该 可 以 发 现 有 些 不 太一 样 ， 他 在 目前 所 在 路 径 和 后 面 


加 上 了 个 高 亮 的 [master] 字样 。 这 段 提 示 ， 会 显 
示 你 目前 所 在 工作 目录 的 各 种 状态 ， 如 果 看 得 懂 的 
话 ， 是 一 个 非常 有 用 的 资讯 来 源 ， 可 以 让 你 在 用 命 
令 列 工具 操作 Git 时 ， 少 打 很 多 qit status 指令 
来 查询 目前 工作 目 人 录 的 状态 。 这 部 分 会 再 下 一 篇 文 
章 中 特别 说 明 。 


在 本 机 建立 一 个 共用 的 储存 库 (shared 


repository') 


共用 储存 库 (shared repository) 是 指 建立 一 个 Git 

储存 库 但 不 包含 工作 目录 ， 这 种 情况 比较 常 发 生 在 

Linux 作业 系统 下 ， 因 为 在 Linux 作业 系统 下 通常 

都 是 多 人 使 用 同一 台 Linux 主机 。 验 然 在 Windows 

作业 系统 也 可 以 这 样 使 用 ， 不 过 我 们 的 开发 环境 大 

多 还 是 在 Windows Client 的 环境 ， 比 较 少 有 多 人 共 
一 台电 脑 的 情况 。 


如 果 要 建立 共用 储存 康 ， 可 以 使 

用 sit init --bare 指令 建立 ， 如 下 图 示 。 你 可 以 
发 现 ， 当 5it init 加 上 --bare 参数 人 后， 他 会 在 

当前 目 杀 建立 所 有 Git 储存 库 的 相关 档案 与 资 料 

夹 ， 你 必须 特别 注意 ， 这 个 资料 夹 不 能 直接 拿 来 做 

开发 用 途 ， 只 能 用 来 储存 Git 的 相关 资讯 ， 大 多 数 


情况 下 ， 你 都 不 麻 该 手动 编辑 这 个 资料 灾 的 任何 榴 


案 ， 最 好 透 过 git 指令 进行 操作 。 


加 Windows Powershell 


KK vdemo> mkdir shared-repos1tory 


纪 多 : C:\demo 


lode 


四 ---- 2013/9/19 下午 05:32 shared-repository 


K :Ndemo> cd .Nshared-repository 

KC:N\demoNshared-repository> git 1Tnit --bare 

Initialized empty Git repository in C:/demo/shared-repository/ 
:demoNvshared-repository> dir 


中 多 : C:\demoNshared-repository 


LastWrTteTime Length 


23 HEAD 


:NdemoNvshared-repository> 。 


由 於 这 是 一 个 “没有 工作 目 色 的 纯 储 存 库 ，， 所 以 
共用 储存 库 也 有 个 别名 叫做 ' 裸 储 存 库 ， (bare 


repository)。 


再 次 强调 ，Git 属於 “分散 式 版 本 控 管 ， ， 每 个 人 都 
有 一 份 完 整 的 储存 康 (Repository)。 也 就 是 说 ， 当 你 
想 要 建立 一 个 “工作 目录 ,， 时， 必须 先 取得 这 个 

/ 裸 储 存 库 , 的 内 容 回来 ， 这 时 你 必须 使 

用 sit clone [REPO_URI] 指令 上 复 揭 ，(clone) 一 
份 回来 才 行 ， 而 透 过 sit clone 的 过 程 ， 不 但 会 自 
动 建立 工作 目录 ， 还 会 直接 把 这 个 裸 储存 库 , 完 


整 的 复 秽 回来 。 这 个 复 拒 的 过 程 ， 就 如 同 ' 完整 备 
份 : 一 样 ， 是 把 所 有 Git 储存 库 中 的 所 有 版 本 纪 
外 、 所 有 版 本 的 档案 、… 等 等 ,所 有 资料 全 部 复 秽 
回来 。 完 整 的 指令 操作 过 程 可 以 参考 以 下 图 示 : 


天 posh~git ~ shared-repository fmaste] 


:vdemo \shared- repos1tory> cd .. 
\demo> mkdir 9git-workspaces 


Lastiwr1TteTime Length Name 


git-workspaces 


:Ndemo> cd .\git-workspaces 
\demo\git-workspaces> 91it clone Civdemo\vshared-repository 
Ts 1nto “shared- repos itory " 。 
warning: You appear to have cloned an empty repos1tory. 
IE 
:NdemoNvgit-workspaces> cd .Vshared- 
:NdemoN\git-workspacesN shared- repository [master]> dir 
:Ndemo\git-workspacesN\shared-repository Lmaster]> dr .\. 


目 尔 : C:\demo\git-workspaces\shared-repository\.g9it 


LastiwriTteTime Length Name 


branches 
hooks 
info 
obJjects 
refs 

7 config 

73 descr1ption 

AD 


在 实务 上 ， 会 使 用 ' 共用 储存 庆 , 或 ' 裸 储存 库 ， 
的 方式 可 能 有 绑 种 : 


。 在 一 台 多 人 使 用 的 机 器 上 进行 协同 开发 ， 可 并 
放大 部 分 人 杀 这 个 裸 储存 库 的 资料 炎 , 公有 
唯 读 权 限 ， 只 让 一 个 人 或 少许 人 才 有 写 入 权 
限 。 

。 有 些 人 会 把 裸 储 存 庆 放 到 Dropbox 跟 自 己 的 多 


台电 脑 同 步 这 个 裸 储 存 库 


请 注意 : 办 然 "工作 目录 ,， 下 的 .sit 目 销 也 是 一 个 
-储存 库 ，， 不 过 工作 目 色 下 的 储存 库 还 包含 一 些 
工作 目录 下 的 索引 资讯 ， 纪 销 著 工 作 目 凶 下 的 状态 
资讯 ， 这 些 状态 资讯 不 会 出 现在 〈“ 共用 储存 库 , 壬 
面 ， 这 和 里 只 有 版 本 资讯 而 已 (也 就 是 Git 的 物件 资 
讯 )。 


在 GitHub 或 其 他 Git 平台 建立 过 端的 
储存 库 (remote repository) 

其 实 下端 储存 库 , 跟 "共用 储存 库 ， 绑 平 是 一 柑 
的 ， 差 别 仅 在 於 “共用 储存 库 ， 大 多 使 用 直接 的 档 
案 存 取 ， 而 “各 端 储存 康 ， 通 营 使 用 SSH, Git 
protocol, HTTP 等 协定 可 " 乏 端 , 存 取 Git 储存 
库 ， 其 他 的 使 用 方式 基本 上 是 一 样 的 。 


以 下 示范 透 过 GitHub 建立 储存 库 ， 芷 将 储存 库 复 
秽 回 本 地 的 情 沉 


。 先 登入 GitHub， 然 后 建立 一 个 新 的 储存 库 


Repositories You contribute to 


目 err 0 食 
csswizardry/CSS-Guidelines 2.604 食 
息 miniaspycapco 0 食 
remy/'jsbin 1.341 食 
patrickariUjiQuery-Plugin-Boile.. 6 食 


Your repositories (14) 


Fin da Repos itormy. 二 
All Repositories ”Public ”Private Sources “Forks 
加 AR 
DotNetZzipPitfall 
名 angularjs-tw 
名 CSS-Guidelines 


四 frontend-tools 


。 设 定 GitHub 专案 的 相关 资讯 下 建立 储存 库 


局 马 Explore Gist Blog Help 


Owner 


慎 doggy8088 ~ 


Public 
Anyone can See this repository. You choose who can commit 


CU Private 
You choose who can see and committo this repository 


Initialize this repository with a README 
This will allow youto egit clonetihe repository immediately 


Add gitignore: None ~ Add a license- None 


人 


5 ) Create repository 品 


立 完成 后 ， 他 会 提示 你 要 如 何 取得 该 专案 
或 将 你 本 地 现 有 的 专案 汇 入 到 GitHub 


doggy8088 / sandbox 


Quick setup 一 ifyouve done this kind ofthing before 


厅 Setupin Desktop 车 
HP SSH hzctps://gichub.com/doggy8088/sandbox.git 要 
Copyto clpboard 
We recommend evwery repository include a README. gnore 
Create a new repository on the command line 


touch READNE .md 
git init 

Eit add README .md 

Bit commit -m "first commit" 

Sit remote add origin https://github.com/dogEgy8688/sandbox.E 广 
git push -u origin master 


。 如 上 图 ， 我 们 可 以 在 Quick setup 的 地 方 点 吉 


"Set up in Desktop"， 你 的 电脑 会 自动 开 艇 
GitHub for Windows 工具 ， 契 自动 复 移 (clone) 
这 个 储存 库 回 来 ， 花 且 建 立 工作 目 凶 。 


。 你 也 可 以 将 让 端 Git 储存 库 的 网 址 复 揭 (Copy) 
下 来 ， 然 后 执行 sit clone [REPO_URL] 即 可 
复 揭 (clone) 一 份 回来 。 


弛 posh~gt ~ sandbox [masteq] 


e cloned an empty 


今日 小 短 


以 上 就 是 三 种 建立 Git 储存 库 的 方式 。 我 重新 整理 
一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git init 
。gitinit --bare 
。git clone [REPOSITORY_URI] 


参考 壬 结 


GETTING AND CREATING PROJECTS - Git 
Reference 

。 Git for Windows 

GitHub for Windows 


。 HOME 
。 回 目 销 
。 前 一 天 : 在 Windows 平台 必 装 的 三 套 Git 工 


由 亚 


下 天 : 常用 的 Git 版 本 控 管 指令 


第 04 天 : 常用 的 Git 版 本 控 
管 指令 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/04.md 


本 篇 文章 将 带 大 家 学 会 效 个 最 重要 也 最 基本 的 版 控 
工作 ， 其 中 将 包含 基本 的 档案 操作 如 新 增 、 删 除 、 
重新 命名 档案 ， 提 交 释 更 (建立 新 版 本 )、 碍 询 压 史 
纪 作 等 工作 。 


准 位 工作 目 甸 


复习 一 下 上 一 篇 “第 03 天 : 建立 储存 库 , 的 内 
容 ， 我 们 直接 来 建立 一 个 本 地 储存 库 ， 即 可 开始 本 
篇 文章 的 所 有 练 普 。 


mkadic g9it-dqemo 
cq 9it-dqemo 
Ge 巧 maile 


新 增 杨 案 


我 们 在 工作 目 杀 下放 一 些 档案 ， 至 於 放 什么 档案 都 
可 以 ， 总 之 先 复 抽 一 些 现 有 的 档案 与 目录 进 到 目前 
的 工作 目录 下 。 


本 篇 文章 ， 我 将 以 YEOMAN 工具 ， 快 速 产生 一 个 
webapp 范例 网 站 ， 只 要 一 个 指令 就 可 以 建立 一 个 
完整 网 站 : 


YO webapPp 


卫 1 咱 


主 : 关於 YEOMAN 在 Windows 平台 的 使 用 ， 可 以 
参考 笔者 的 文章 如 何在 Windows 平台 安装 旺 使 用 
Yeoman 1.0 相关 工具 ， 该 文 详 述 完整 的 安装 与 使 
用 过 程 。 


涂 


新 增 了 档案 之 后 ， 如 果 你 还 在 Git Shell 介面 下 ， 朵 
该 会 立刻 看 到 如 下 图 的 提示 : 


posh~git ~ git-demo [maste] 


ser\DocumentsN\GitHub\git-demo 


Length Name 


2 
12000 Gruntfi1le 5 
980 package. json 


ents\NGitHub\git-dema 


也 就 是 以 下 这 段位 於 路 径 和 后 面 的 提示 : 


[master +10 ~<0 =0 1 


在 这 段 提示 的 地 方 ， 你 可 以 看 到 绑 个 东西 : 


如 果 和 要 要 


master 代表 目前 工作 目录 是 master 分 支 ， 也 
是 Git 的 预 设 分 支 名 称 。 

5 红色, 的 数字 都 代表 Untracked (未 追 跳 ) 的 
档案 ， 也 就 是 这 些 变 更 都 不 会 人 千 入 版 本 控 管 。 
+10 代表 有 10 个 “新 增 , 的 档案 
~0 代表 有 0 个 ' 修改 , 的 档案 
-0 代表 有 0 个 5“ 删除, 的 档案 


= 新 增 的 枚 案 加 入 到 Git 版 本 控 管 ， 


将 这 些 


你 必须 下 巡 以 下 指令 : 


gsaaae 


如 此 一 来 ， 这 个 工作 目录 下 所 有 的 档案 、 目 录 和 与 子 
目录 下 的 所 有 档案 ， 全 部 都 会 被 加 入 到 这 个 Git 工 
作 目 录 的 【索引 ] 或 【 快 取 】 之 中 。 请 注意 : 此 时 普 
没有 建立 任何 版 本 ， 只 是 告知 Git 这 些 档案 ' 即 
将 , 被 加 入 Git 版 本 库 而 已 。 


如 下 图 示 ， 是 我 这 超 执 行 完 sit adqa . 之 后 的 结 
果 ， 这 和 里 所 发 生 的 warning 讯息 不 是 很 严重 ， 有 黑 
趣 了 解 的 人 可 以 参考 笔者 的 另 一 篇 文章 : Git 在 
Windows 平台 处 理 断 行 字 元 (CRLF) 的 注意 事项 。 


\ 过 有 趣 的 地 方 在 於 
成 了 ' 绿色 的 数字 ， 


缠 和 
2 


\Documents 
i11 be _replaced by 
wi11 have its original 


LF wi11 be by 


wi11 have its original 


: LF wi11 be replaced by 


wi11 have its original 
: LF wi11 be _ replaced by 
wi11 have its or 1 


LF_ wi11 be replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


: LF wi11 be _ replaced by 


wi11 have its original 
: LF wi11 be replaced by 
wi11 have its original 


: LF _wi11 be_replaced by 


wi11 have its original 
LF_wi11 be_replaced by 
1 have its original 


: LF wi11 be replaced by 
1 


wi11 have its orig 


: LF wi11 be repjaced by 


wi11 have its original 


: LF wi11 be replaced by 


wi11 have its original 
: LF wi11 be replaced by 
w111 have its original 
: LF _wi11 be et by 


: LF 
wi11 have its or1i 

: LF wi11 be replaced by 
wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


: LF wi11 be 二 扑 by 


wi111 have its original 
LF wi11 be by 
e e wi1T have its original 


CRLF 
]1ine 
CRLF 
1ine 
CRLF 
]1ine 
CRLF 
1ine 
CRLF 
]ine 
CRLF 
1ine 
CRLF 
1ine 
CRLF 
1ine 
CRLF 
1ine 
CRLF 
]ine 
CRLF 
1ine 
CRLF 
]ine 
CRLF 
1ine 
CRLF 
]ine 
CRLF 


posh~git ~ git-demo [maste] 


NG1tHub\g1t-demo 


in .bowerrc- 
endings in your working 
到 orconfig. 
endings in your working 
gnore. 
1n your working 
endings in r working 
in Gruntfile.js. 
endings in your working 
in appy/ .htaccess。 
endings in your working 
Tn app/404. htm1 


endi ngs in your work 

in ap obots .txt。 
endings in your wor 

in app/scripts/app.] 
endings in your working 
in app/yscripts/main.]Js. 
endings in your working 


> gt add 


drectory. 
directory-. 
drectory。 
directory. 
directory. 
directory. 
directory. 
由 rectory. 
directory. 
d 趾 rectory. 


directory. 


in app/styles/main.scss 


endings in your 
Tin bower. json。 
endings in your 
in package. Json. 
endings 1n your working 
in test/index.htm1. 


working 


working 


1ine e 


CRLF 
1ine 
CRLF 
1ine 
CRLF 
1ine 
CRLF 
]ine 
CRLF 
1ine 


endings 

1n 上 es 

endings 

in tes 

endings 

in 上 est/ 

endings 

Tin test/spec/test 
endings in your working 


Hub\git-demao 也 ]> 


人 


由 rectory。 
directory. 
directory-. 
directory. 
directory. 


drectory. 


。CS 


drectory. 


卫 .站 


由 rectory. 


directory. 


红色 的 数 子 , 现在 公 
这 里 所 代表 的 意义 是 


1 机 1 的 数字 都 代表 Staged (准备 好 ) 的 档 
些 释 更 才 会 进入 版 本 控 管 。 


， 也 就 是 这 


423 代表 有 23 个 "新 增 


个 版 本 


1 的 横 案 将 被 建立 一 


~0 代表 有 0 个 "修改 , 的 案 将 被 建立 一 个 


版 本 


-0 代表 有 0 个 “删除 ， 


本 


的 


当 案 将 被 建立 一 个 版 


但 原本 不 是 只 有 +10 (红色 ) 而 已 吗 ? 怎么 执行 完 后 
变 成 了 +23 (绿色 ) 呢 ? 


我 们 执行 sit reset 重 设 一 下 工作 目 销 的 索引 状 
能 ， 然 后 再 执行 一 次 ait status 查询 当前 工作 目 
杀 的 详细 状态 ， 如 下 图 示 : 


mentsN\G1tHub\g1t-demao 
entsNG1itHub\git-dema 


."to include in what wi11 be committed) 


S ing adde 包 to commit but untracked files present (use“git add” to track) 
ersMUser\Docum Rs GitHub\git-dema > 


你 可 以 发 现 ， 这 逮 列 出 的 只 有 “ 第 一 屋 目录 下 的 档 
案 与 目 杀 ,， 而 已 ， 因 为 git 不 会 这 个 时 候 去 查 到 底 
目 色 下 到 搬 有 多 少 枚 案 没 有 被 追 跳 。 


当 我 们 执行 sit ada . 之 后 ， 再 执行 一 

次 sit status 查询 状态 ， 你 可 以 发 现 巡 子 目 销 下 
的 档案 也 都 全 部 被 加 入 了 ， 所 以 这 个 数字 才 会 变 
多 ， 如 下 图 示 : 


DOcumentsNGitHubN\gqit-demo master 


新 增 部 分 档案 


剖 | 辣 | 提 到 的 sit adq . 指令 会 自动 将 所 有 档案 ( 含 
子 目 公 的 档案 ) 加 入 到 工作 目录 勾引 中 ， 有 时 候 我 们 
只 想 让 特定 目录 或 特定 档案 加 入 版 本 ， 这 时 你 也 可 
以 指定 特定 目录 ， 或 利用 万 用 子 元 来 加 入 档案 。 


我 们 再 执行 一 次 sit reset 重 设 工作 目 销 的 索引 状 
胀 ， 然 后 用 sit add app 加 入 app 这 个 资料 夹 与 
其 下 的 所 有 档案 ,还 有 用 sit aaa .* 新 增 所 有 

野 :开头 的 档案 ,如 下 图 示 : 


g1 廿 Fese 
dir 


node_modules 

十 es 七 

.bowerrc 
.editorconfig 
.g1tattributes 
.gitignore 
.Jshintrc 


git add app 


LF w111 be SP by 
w111 have its original 11 1 in yi K directory-. 
: LF wi11 be replaced by 
i11 have its original in your working drectory. 
: LF wi11 be _ replaced by ndex.- htm1. 
w111 have its original 11 1 Tin your working drectory. 
LF wi11 be _ replaced by obots .txt。 
wi11 have its original in your working drectory. 
LF wi11 be _ replaced by 1 cripts/app.Jjs 
wi11 have its original 11 1 in your working directory- 
: LF wi11 be _ replaced by ] 1 
wi11 have its original 11 S /| K directory-. 
LF_wi11 be_replaced by i 
有 have its original 1ine in youUr 册 drecto 
IOCUmentsNG1tHubN\git-demo Taster 
111 be replaced by CRLF in .bowerrc 
wi11 have its original line endings in your working directory. 
LF wi11 be replaced by CRLF in .editorconf 
wi11 have its original 1ine endings in your working directory. 
LF w111 be replaced by CRLF in .gitignore- 
w111 have Tits or 1ine endings 1n your working drectory-. 
LF wi11 be replaced by CRLF in .jshintrc 
wi11 have its original 1ine Tin your working drectory， 


| 


# On branch master 
Initial commi 七 


Changes， to be committed : 
(use "git rm --cached <file>...” unstage) 


Untracked files: 
(use "git add <file>... 


to include in what wi11 be committed) 


CINUsersNUse DOcumentsNGitHub\git-demo master 


在 执行 的 过 程 中 ， 你 应 该 可 以 发 现 ， 在 执 
行 git _ add 的 过 程 中 ,，Git Shell 提示 的 文字 也 有 了 


些 变 化 ， 现 在 同时 出 现 了 ' 绿色 的 数字 , 与 " 红色 
的 数字 ，， 所 代表 的 意思 跟 上 述 是 一 样 的 ， 是 不 是 
非常 方便 辨识 ! 当 你 需要 知道 详情 才 需要 执 


行 可 开 七 名 七 喜 蕊 下 沁 指令 。 


广 : 详细 的 指令 与 参数 说 明 ， 可 以 输 
入 9lit help adqd 查询 完整 的 文件 。 


提交 释 更 / 建立 版 本 


这 时 我 们 预计 要 建立 一 个 新 版 本 了 ， 在 建立 版 本 之 
前 ， 我 们 还 是 把 所 有 档案 给 加 入 吧 ， 请 各 位 在 执行 


一 次 git add . 命令 。 


建立 版 本 的 指令 如 下 : 


Ganeeemrmaste 


git_ commit -m "版 本 纪 他 的 说 明文 字 " 


在 Git 版 本 控 管 中 ， 所 有 的 版 本 都 必须 所 有 ' 版 本 
纪 凶 的 说 明文 字 , ( 简称 Log )， 不 像 Subversion 
预 设 可 以 签 入 “没有 版 本 纪 杀 褒 明 , 的 版 本 。 所 以 
当 你 直接 输入 sit commit 的 话 ， 预 设 会 开启 


Notepad (记事 本 ) 让 你 输 入 这 个 版 本 的 于 访 局 。 开启 
后 的 档案 会 有 很 多 # 符号 开头 的 文字 ， 这 些 都 是 广 
解 ， 不 会 成 为 Log 的 一 部 分 。 


如 下 图 示 ， 是 我 输入 的 讯息 文字 : 


Pile Edit View Settings 2 


口 攻 急 园 | ex 所 本 | 的 入 | 图 和 SI 国 刀 | 虹 
志 
2# Please enter the commit message for your changes. Lines starting 
3## with “#”wi11 be ignored，and an empty message aborts the commit. 
4## On branch master 
5 天 
5 兰 Initial COommiT 
了 娠 
8s# Changes to be committed: 
引产 (use “9git rm --cached <file>...” to unstage) 

10 大 

11 涯 new file: -bowerrc 

1a## new file: -editorconfig 

13## new file: -gitattributes 

14 兰 new file: -gitignore 

15# new file: -jshintrc 

15# new file:  Gruntfile.js 

17 兰 new file: appy/ .htaccess 

185 兰  new file: app/404.html 

13 兰 new file: app/favicon. ico 

20 兰 new file: app/index.html 

21# ”new file: appy/robots.LXt 

22 兰 “new file: app/scripts/app. js 

23# ”new file: app/scripts/he11o. coffee 

24## new file: app/scriptsymain. js 

25 兰 “new file: app/styles/ymain.-scss 

26# new file: bower. json 

27 关 new file: package. json 

25# new file: testy/index.html1 

295## new file: test/]ibychai. js 

30## ”new file: test/]ib/yexpect. js 

31## new file: testy/]ibymochaVymocha.css 

32 关 new file: test/]ibymocha/ymocha. js 

33## new file: test/spec/test. js 

34 尖 

Ln1:36 Col1T Sel 64 1.02KB UTF-8 Signature CR+LF INS Default Te 


当 你 按 下 Ctrl+S 储存 这 仙 文 字 档 ， 这 时 还 不 会 建立 
一 个 新 版 本 ， 还 必须 关闭 这 个 机 视窗 ， 这 时 
才 会 正式 建立 版 本 ， 如 下 图 示 : 


:Users 
[master 


warnlng : 


NUser\Documents 

(Croot-commit》) 62d22 ] 
LF w1i11 be _ replaced by 
wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


e wi11 have its original 


LF wi11 be _ replaced by 
wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi111 have its original 


varning: 
The file 
warnin 
The file 
warning: 


Warn1nmt 


The 千 
warnlng : 


he filie 


varning : 
The file 
varning : 
The file 
warning : 
The file 
23 files changed，10856 insertions(+) 


Create 
create 
Create 
Create 
create 


LF wi11 be _ replaced by 


wi11 have its original 
LF wi11 be _ replaced by 
wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF w111 be _ replaced by 


wi11 have its original 
LF wi11 be _ replaced by 
wi11 have its original 


LF wi11 be _ replaced by 


wi111 have its original 


LF wi11 be replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


LF wi11 be _ replaced by 


wi11 have its original 


100644 
100644 
100644 
100644 
100644 


mode . bowerrc 
mode 
mode 
mode 


mode 


.gitignore 
.Jshintrc 


.editorconfig 
.gitattributes 


Posh~git ~ git-demo [masten] 
> g1 廿 COmm 七 
建立 的 webapp 李 索 


奈 雪 yeoman 


endings in your working 
in .editorconfig. 
endings in your working 
in .glitignore. 

endings 1n your working 
in .jshintrc. 
endings in your 
in Gruntfile.js. 
endings in your working 
1n appy/ .htaccess. 
endings in your working 
in app/404.html1. 
endings in your working 
in app/index.html1. 
endings in your working 
in appy/yrobo 

endings in 

in app/scrip: 

endings in Your work ng 
in app/scripts/main.js. 
endings in 

1n ap ty 
endings in Your 
Tin bower. json. 
endings in your 
in package. Json. 
endings 1n your working 
/index. htm1. 

1n your working 
1ib/chai.Jj 

in your work 
1ib/expect. js. 
Tn your working 


working 


working 


working 


endings 


endings 
in 上 test 
endings 
in 廿 es 七 

endings 
1n 廿 es 上 t/ 
endings 


in your working 


Jr working 
5 est. ]s。 
1n your working 


/iibyVymocha/mocha 


门 ibymocha/mocha 


directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
directory. 
css 

directory. 
下 ER 


directory. 


100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 
100644 


mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 
mode 


Create 
Create 
Create 
Create 
Create 
create 
create 
Create 
create 
create 
create 
Create 
Create 
Create 
Create 
Create 
create mode 100644 
create mode 100644 
:NUsersNUser\Documents 


Sruntfile. 人 ] 
htaccess 
04.htm] 
avicon. ico 
ndex. htm1 
oObots .txt 

app/scripts/app. js 

SEE coffee 

app/Vscripts/main. 荆 。 

app/sty1es/main.scs 
bower. json 

package. json 

test/1ndex. htm1 


test/spec/test. js 
\GitHubN\git-dema 了 


就 只 剩 
名 有 任何 要 被 


建立 版 本 完 人 后 ，Git Shell 的 提示 
下 [master] 字样 了 ， 代 表 目 前 已 经 没 
建立 版 本 的 么 引 或 快 取 。 


如 


: 详细 的 指令 与 参数 说 明 ， 可 以 办 


入 9it helpP commit 但 询 完 整 的 文件 。 


得 询 奈 史 纪 全 


由 於 我 们 同 | 辣 | 建 立 了 一 个 人 版本， 是 我 们 想 要 碍 询 版 
本 的 历史 纪 欠 ， 可 以 输入 以 下 指令 : 


ONEEOG 


posh~git ~ git-demo [masten] 
站 > gt 1og 


有 时 候 纪 公 越 来 越 多 ， 你 也 可 以 透 过 以 下 指令 限制 
输出 的 版 本 数量 ， 你 只 要 透 过 一 个 减 号 ( - ) 与 一 个 
数字 ， 就 可 以 限定 输出 最 近 绑 笔 纪 色 : 


ganeoo 症 三 可 人 


: 详细 的 指令 与 参数 说 明 ， 可 以 轮 


9it helpP 1od 查询 充 整 的 文件 。 


> 弗 


删除 榴 案 


在 Git 指令 列 工具 中 也 有 个 rm 指令 ， 可 以 用 来 删 
除 档案 。 例 如 我 们 想 删 除 cruntfile.js 这 个 档 
案 ， 可 以 输入 以 下 指令 : 


DESIGNSDNONEOEODES 汪 | 全 L 


这 个 sit rm 的 指令 执行 的 时 候 ， 会 同时 做 两 件 
事 : 


1. 删除 工作 目录 快 取 的 'Gruntfile.js' 这 个 档案 (用 
来 标示 这 个 删除 档案 的 动作 要 列 入 版 本 控 管 ) 

2. 删除 工作 目录 下 的 'Gruntfile.js' 这 个 实体 档案 
(代表 真 的 把 这 个 实体 档案 给 删除 ) 


主 : 详细 的 指令 与 参数 说 明 ， 可 以 输 
入 9it helP rm 查询 完整 的 文件 。 


在 Git 指令 列 工具 中 也 有 个 mv 指令 ,可 以 用 来 伙 
更 档案 或 目录 的 名 称 。 例 如 我 们 想 把 test 目 凶 更 
名 为 unit-test 名 称 ， 可 以 输入 以 下 指令 : 


GEEEmV 琶 世 S Se 有 册 相 已 三 长 SS 起 


UserNDocumentsNGitHubN\git-demo 


主 : 详细 的 指令 与 参数 诊 明 ， 可 以 输 
入 9it helPp mv 但 询 完 整 的 文件 。 


是 示 工作 目 色 的 么 5| 状 感 


刚刚 我 们 一直 会 看 到 sit status 来 显示 工作 目 销 
的 状态 ， 你 也 可 以 使 用 sit status -s 来 显示 较为 
情 简 的 版 本 。 


广 : 详细 的 指令 与 参数 说 明 ， 可 以 轮 


入 9it help status 查询 充 整 的 文件 。 


重 置 目前 的 工作 目 针 


我 们 曾经 学 过 如 何 利用 sit reset 重 置 目 前 工作 目 

销 的 索引 状态 ， 但 请 注意 ， 这 个 指令 预 设 只 会 重 置 
索引 状态 ，， 那 些 你 用 sit xm 删除 的 目 销 或 档 

案 ， 还 是 用 sit mv 更 名 的 目 人 或 档案 ， 透 

过 sit reset 都 组 法 把 " 实体 档案 , 给 救 回来 。 


如 果 想 把 工作 目录 也 给 还 原 到 目前 的 最 新 版 ， 则 必 
须 输 入 以 下 指令 : 


9 下 ESSe 臣 是 三 三 上 二 站台 


: 详细 的 指令 与 参数 说 明 ， 可 以 输 


dit helP reset 查询 充 整 的 文件 。 


> 开 


冰 原 其 中 一 个 被 改 坏 的 枚 案 


如 果 档 案 编 辑 到 一 半 ， 发 现 被 改 坏 了 ， 你 希望 能 救 
回 没 修 改 前 的 版 本 ， 过 时 你 可 以 利用 以 下 指令 冰原 


9it checkout master Guntftile.]Jjs 


这 段 指令 的 意思 是 把 master 分 支 中 最 新 版 的 
Grunefile.js 给 还 原 ， 由 於 我 先前 已 经 把 Gruntfile.js 
给 删除 了 ， 为 了 要 救 回 这 一 个 档 ， 可 以 用 这 个 方式 
救 回 。 这 样 可 以 避免 使 用 sit reset --hard 一 次 
把 所 有 档案 都 给 还 原 了 ! 


请 注意 ， 还 原 的 过 程 也 会 一 儒 复 原 工 作 目 朱 的 索引 
状态 喔 


: 详细 的 指令 与 参数 说 明 ， 可 以 办 


git help checkout 查询 完整 的 文件 。 


> 避 


今 今日 小 颖 


今日 的 文章 ， 可 以 说 是 在 Git 版 本 控 管 中 不 断 会 


复 使 用 的 指令 与 参数 ， 必 须 非常 熟练 才 行 ， 接 下 来 
的 文章 ， 将 会 详细 探讨 Git 版 本 控 管 的 内 部 结构 ， 
干 万 个 要 销 过 ! 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git init 

git add . 

git add app 广 
git add“.txt 
。git status 


git status -S 
。git commit 
。git commit -m "版 本 纪 杀 的 褒 明 文字 " 


git log 
。git log -10 


git rm .txt 
。git rm app 生 .htm 
。git mv oldname' newname 


git reset 
。 git reset --hard 


git checkout master filename 


。 BASIC SNAPSHOTTING 


*。 HOME 

。 回 目录 

。 前 一 天 : 建立 储存 库 

。 下 一 天 : 了 解 储存 库 、 工 作 目 录 、 物 件 与 索引 
之 问 的 关 傈 


第 05 大 : 了 解 储存 库 、 工 作 
目录 、 物 件 与 系 引 之 问 的 关 体 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/05.md 


在 使 用 Git 版 本 控 管 的 过 程 中 ， 有 些 很 基本 的 观念 

必须 被 建立 ， 这 样 才能 更 有 效率 也 更 有 意义 的 学 下 

去 。 有 靖 芭 且 正 确 的 盯 念 支持 ， 不 但 有 助 於 你 学 习 

Git 指令 操作 ， 更 重要 的 是 ， 学 习 Git 相关 知识 也 会 
更 加 上 手 。 


了 解 储存 库 


我 们 要 使 用 Git 进行 版 本 控 管 ， 很 自然 的 ， 我 们 需 
要 一 个 版 本 库 , 来 储存 这 些 版 本 资讯 ， 而 英文 的 
Repository 就 是 这 个 意思 ,笔者 习惯 将 这 个 英文 翻 
证 成 【储存 库 ， ， 代 表 用 来 储存 所 有 版 本 的 一 个 空 
间或 一 个 资料 灾 与 一 堆 档案 。 


如 果 有 Git 使 用 经 验 的 人 ， 应 该 很 清楚 ， 建 立 储存 


库 有 很 多 方法 ， 如 果 你 要 在 任意 一 个 资料 来 建立 一 
个 Git 储存 库 ， 只 要 输入 以 下 指令 就 可 以 建立 完 
成 : 


Gas 


我 们 透 过 下 图 建立 Git 储存 库 的 过 程 来 说 明 ， 透 过 
这 张 图 我 们 可 以 很 清楚 的 知道 ， 当 我 们 在 GAgit- 
demo 目录 下 款 行 git init 之 后 ，Git 会 自动 玫 有 我 们 建 
立 一 个 所 谓 的 Git repository 在 该 目 销 的 .git 目 销 
下 ， 各 位 不 用 怀疑 ， 这 个 .git 资料 丈 ， 就 是 一 个 完 
整 的 Git 储存 库 ， 未 来 所 有 版 本 的 变更 ， 都 会 自动 
储存 在 这 个 资料 来 壬 面 。 


[| Ceingcwswe 


:N\>mkdqdir git-demo 
:N\>cd 9it-demo 


:Ngqit-demo>git init 
Initialized empty Git FepositoFky in G:-git-demo~-git~ 


:、\St 一 demo>di 


9 人 档案 


3 个 目 圭 


全 
举 量 TEMPORNRRY 
92EB-6060 


efs 
description 
hooks 
info 
23 HEhD 
157 config 
P91369xA14 站 : 《DIR> ohbjects 
档案 253 二 
4-195.934-298 


:Ng9it-demo> 


了 解 工作 目 针 


在 上 述 这 个 例子 壬 ， 目 多 Ggitrdemo 此 时 就 会 自 
动 成 为 我 们 的 “工作 目录 ,， (working directory)。 所 
谓 "工作 目 杀 ,的 意思 ， 人 
专案 档案 ， 未 来 都 会 在 这 个 目录 下 进行 编辑 ， 扰 论 


是 新 增 档案 、 修 改 档 案 、 删 除 档案 、 档 案 更 名 、.… 
以 及 所 有 其 他 Git 相关 的 操作 ， 都 会 在 这 个 目 朱 下 
完成 ， 所 以 才 称 为 “工作 目录 , 。 


我 们 在 操作 Git 相关 指令 参数 的 时 候 ， 也 通常 都 是 
在 "工作 目录 , 下 执行 的 。 


由 於 在 使 用 Git 版 本 控 管 时 ， 会 遭遇 到 很 多 分 支 的 
状况 ， 所 以 工作 目录 很 有 可 能 会 在 不 同 的 分 支 之 问 
进行 切换 ， 有 些 git 指令 在 执行 的 时 候 ， 会 一 供 更 
新 工作 目 杀 下 的 档案 。 例 如 沼 你 使 用 git checkout 
切换 到 不 同 分 支 时 ， 由 於 目前 分 支 与 想 要 切换 过 去 
的 分 支 的 目录 结构 不 太一 样 ， 所 以 很 有 可 能 会 将 你 
目前 工作 目录 下 的 档案 进行 更 新 ， 好 让 目前 的 工作 
目录 下 的 这 些 目 杀 和 与 档案 ， 都 与 另 一 个 要 切换 过 去 
的 分 文 下 的 目录 与 档案 一 样 。 


所 以 ， 送 时 的 保持 工作 目 杀 的 乾 泽 ， 是 版 本 控 管 过 
程 中 的 一 个 基本 原则 ， 更 尤其 是 日 后 要 进行 合 供 的 
时 候 ， 这 点 尤其 重要 ， 相 关 知 识 我 会 在 日 后 的 文章 
中 进一步 说 明 。 


了 解 Git 的 资料 结构 
在 Git 壬 有 两 个 重要 的 资料 结构 ， 分 别 是 “物件 ， 


与 索引, 。 


物件 : 用 来 保存 版 本 库 中 所 有 档案 与 版 本 纪 针 ， 
索引 则 是 用 来 保存 当下 要 进 版 本 库 之 前 的 目 针 
状态 。 


关於 物件 


所 谓 的 “ 物件, 是 一 个 "特别 的 榴 案 ， ， 该 档案 的 
彦 生 过 程 很 有 趣 ， 是 将 一 个 档案 的 内 容 中 取出 ， 透 
过 内 容 产 生 一 组 SHA1 杂 汪 值 ， 然 后 依照 这 个 
SHA1 杂 滩 值 命名 的 一 个 档案 。 


在 使 用 Git 进行 版 本 控 管 的 过 程 中 ， 所 有 要 进行 控 
管 的 目录 和 与 档案 ， 都 会 先 区 分 ' 目 人 资 讯 ，, 与 " 档 
案 内 容 ，， 我 们 称 为 tree 物件 与 blob 物件 。 


其 中 blob 物件 就 是 把 原本 的 “档案 内 容 , 当成 
blob 档案 的 内 容 (注意 : blob 物件 其 实 就 是 一 个 实体 
当 案 ) ， 然 后 再 将 其 内 容 进 行 SHA1 杂 汉 运算 后 产生 
的 一 个 hash id， 再 把 这 个 hash id 当成 blob 档案 
的 档 名 。 由 此 可 知 ，blob 物件 是 一 个 上 只 有 内 容 ， 
的 档案 ， 其 档 名 又 是 由 内 容 产生 的 ， 所 以 ， 任 何 一 
个 单独 存在 的 blob 档案 通常 对 版 本 控 管 没有 任何 帮 
助 。 


另 一 个 tree 物件 ， 则 是 用 来 储存 特定 资料 夹 下 包含 
哪些 档案 ， 以 及 该 档案 对 应 的 blob 物件 的 档 名 坊 
何 。 在 tree 物件 中 ， 除 了 可 以 包含 blob 物件 的 横 
名 与 相关 资讯 ， 还 可 以 包含 其 他 的 tree 物件 。 所 以 
tree 物件 其 实 融 是 “资料 来: 的 代名词 。 


无 论 blob 物件 与 tree 物件 ， 这 些 都 算是 物件 ， 这 
些 物 件 都 会 储存 在 一 个 所 谓 的 “物件 储存 区 ， 
(object storage) 之 中 ， 而 这 个 物件 储存 区 ,， 预 设 
就 在 上 储存 库 , 的 objects 目 杀 下 ， 如 下 图 示 : 


旧 ， 末 脱 ， TEMPORARY (G] ，git-demo ，.git ， 


EEEEEEEE 
鲍 config / 
轧 description 
售 HEAD 
思 hooks 
人 甩 info 
| 吕 obecs 


丰 refs 


详细 的 物件 结构 ， 我 们 会 在 接 下 来 的 文章 谈 到 。 


双 
中 1 
严 田 
IE 
CE 

二 
汉 


引 , 是 一 个 经 常 遇 动 的 暂 存 档 ， 这 个 档 


案 通 弟 位 於 .git 目录 下 的 一 位 名 为 index 的 档案 。 

桨 单 来 说 ，“" 索引 的 目的 主要 用 来 纪 人 “有 哪些 
档案 即将 要 被 提交 到 下 一 个 commit 版 本 中 ,， 。 换 
名 话说， 如 果 你 想 要 提交 一 个 版 本 到 Git 储存 库 ， 
那 床 你 一 定 要 先 更 新 索引 状态 ， 释 更 才 会 被 提交 出 
去 3 


这 个 索引 档 ， 通 常 保 存 著 Git 储存 库 中 特定 版 本 的 
状态 ， 这 个 状态 可 以 由 任意 一 个 commit 物件 ， 以 
及 tree 物件 所 表示 。 


我 们 通常 不 会 直接 去 编辑 .gitindex 这 个 二 进位 档 ， 
而 是 透 过 标准 的 git 指令 去 操作 这 个 索引 档 ， 针 於 
索引 档 的 操作 指令 大 概 有 以 下 绑 个 : 


。 git add 
。git mv 
。git rm 
。git status 
。git commit 
。git ls-files 


Git 的 “索引 , 是 一 个 介 於 “物件 储存 区 ， (object 
storage) 与 5“ 工作 目 杀 ， (working directory) 之 问 
的 媒介 。 


各 位 也 许 已 经 可 以 猜 到 ， 本 篇 文章 想 关 述 的 这 类 个 
观念 乙 间 的 关 休 ， 可 以 用 以 下 5 个 步 又 解 稳 : 


。 要 使 用 Git 版 本 控 管 ， 你 必须 先 建立 “工作 目 
外 , 与 "版 本 库 ， 。(mkdir git inib) 

。 你 要 先 在 “工作 目录 , 进行 开发 ， 你 可 能 会 建 
立 目 杀 、 建 立 档案 、 修 改 档案 、 间 
等 操作 。 

。 然后 当 你 想 提 交 一 个 新 版 本 到 Git 的 "储存 
库 , 壬 ， 一 定 要 先 更 新 “索引 状态 。(git 
add, git mv, …) 

。 然后 Git 会 依据 “索引 当下 的 状态 ， 沁 定 要 
把 那些 档案 提交 到 Git 的 “储存 亩 ,， 实 。(git 
Status) 

。 最 后 提交 释 更 时 (git commib， 才 会 把 版 本 资 
讯 写 入 到 物件 储存 区 , 当中 (此 时 将 会 袁 入 
commit 物件 )。 


详细 的 索引 结构 与 指令 操作 ， 我 们 会 在 接 下 来 的 文 


章 谈 到 。 


证 : 由 於 tree 的 概念 跟 qirectory 很 像 ,， 所 以 在 看 国外 原 》 


今日 小 给 


今天 探讨 的 Git 飞 柳 ， 最 重要 的 逮 是 在 ' 物件 , 与 
和 票 引 4 之 问 的 关 傈 ， 因 为 没有 乏 引 4 资讯 ，Git 
融 扔 法 建立 版 本 。 


而 基 於 物件, 与 索引. 的 差 蛙 ， 你 应 该 可 以 发 
现 ， 物件, 是 属於 一 种 "不 可 释 的 ， (immutable) 
档案 类 型 ， 任 何 写 入 到 物件 储存 区 , 的 物件 ， 原 
则 上 都 不 会 再 发 生 园 动 ， 因 为 所 有 的 物件 都 是 从 原 
本 的 档案 内 容 凑 生 的 。 我 们 也 可 以 褒 这 是 一 个 " 物 
件 资 料 康 ， (object database)， 且 这 个 资料 库 通 常 
只 会 增加 和 内容， 比较 不 会 有 "删除 内 容 , 或 " 黑 动 
内 容 , 的 情况 ， 只 有 在 执行 git gc 清除 垃圾 资料 时 
才 会 删除 资料 。 "索引 则 是 属於 一 种 "可 释 的 ， 
(mutable) 索引 档 ， 用 来 记 杀 目前 工作 目 销 淮 人 备 要 
commit 的 内 容 。 


当 你 一 步 一 步 的 接近 Git 核心 ， 慢 慢 地 将 模糊 不 清 


的 抽象 概念 ， 转 变 成 具象 的 观念 知识 ， 你 就 不 会 再 
对 Git 感到 不 安 ， 请 继续 努力 学 习 ， 成 功 就 在 前 


。 Git Internals - Git Objects 

。 Pro Git Book 

。Git Magic - 繁 朵 中 文 版 

。 Git (Software) - Wikipedia, the free 
encyclopedia 


。 HOME 

。 回 目 色 

。 前 一 天 : 常用 的 Git 版 本 控 管 指令 

。 下 一 天 : 解析 Git 资料 结构 - 物件 结构 


第 06 大 : 解析 Git 资料 结构 
- 物件 结构 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/06.md 


在 Git 的 资料 结构 中 ，“ 物件 , 是 一 种 "不 可 释 
的 (immutable) 档案 类 型 ， 所 有 储存 在 “物件 储 
存 区 , 的 档案 通常 只 进 不 出 ， 也 不 会 被 修改 内 容 。 
原因 在 於 ， 如 果 你 是 改 了 档案 了 内 容 ， 新 的 内 容 所 
运算 出 来 的 SHA1 杂 汉 值 将 会 与 原 有 物件 的 档 名 不 
一 样 ， 这 导致 Git 无 法 继续 执行 ， 相 对 地 也 对 Git 
储存 库 庆 生 了 一 定 程度 的 保护 作用 。 本 篇 文章 ， 将 
更 加 仔细 地 介绍 Git 的 物件 结构 ， 最 和 后 也 会 透 过 一 
则 影片 ， 详 细 解 说 束 个 物件 被 产 生 的 过 程 与 选辑 。 


关於 物件 次 料 库 


前 一 篇 文章 有 提 到 ， 扰 论 blob 物件 与 tree 物件 ， 
这 些 都 算是 物件 ， 这 些 物 件 都 会 储存 在 一 个 所 谓 的 
7 物件 储存 区 ， (object storage) 之 中 ， 而 这 个 5“ 物 


件 储 存 区 ,， 预 设 就 在 “储存 库 , 的 objects 目 凶 
下 ， 如 下 图 示 : 


服 ， 重 腾 ， TEMPORARY (G] ， git-demo ，_.git 》 


ES 
名 config 7/ 
轧 description 
镶 HEAD 


然而 Git 储存 库 中 的 每 一 个 "物件 ， ， 都 是 以 档 
案 内 容 , 进行 SHA1 杂 汉 还 算出 一 个 hash 值 ， 冰 
用 这 个 hash 值 当 作物 件 的 名 称 ( 档 名 )。 我 们 以 
8a6b275638f3cf164395e65066a1132bb36b7896 
为 例 ，Git 会 先 拿 前 两 个 字 元 (8a) 当 作 目 录 ， 然 后 把 
剩 下 的 hash 值 当 成 档 名 
(6b275638f3cf164395e65066a1132bb36b7896) ， 
这 些 物 件 的 实体 目录 与 档案 也 都 会 放 在 .gitobjects 
目录 下 ， 如 下 图 示 : 


二 .9 A^A ” 衬 短 


U branche 
仿 6b275638 和 cf164395e65065a1132bb36b7895 
加 To R 


物件 的 类 型 
在 这 些 "物件 资料 库 ， 里 面 ， 又 包含 了 4 种 物件 类 


型 ， 分 别 是 : 

1. blob 物件 : 就 是 工作 目录 中 某 个 档案 的 "内 
容 "， 且 只 有 内 容 而 已 ， 当 你 执行 git add 指令 
的 同时 ， 这 些 新 增 档 案 的 内 容 就 会 立刻 被 写 入 
成 为 blob 物件 ， 档 名 则 是 物件 内 容 的 杂 汉 有 运 
算 结 果 ， 没 有 任何 其 他 其 他 资讯 ， 像 是 档案 时 
关 、 原 本 的 档 名 或 档案 的 其 他 资讯 ， 都 会 储存 
在 其 他 类 型 的 物件 里 (也 就 是 tree 物件 )。 

2. tree 物件 : 这 类 物 件 会 储存 特定 目 录 下 的 所 有 
资讯 ， 包 含 该 目 朱 下 的 档 名 、 对 应 的 blob 物 
件 名称 、 档 案 连 结 (symbolic link) 或 其 他 tree 
物件 等 等 。 由 於 tree 物件 可 以 包含 其 他 tree 
物件 ， 所 以 浏览 tree 物件 的 方式 其 实 就 跟 档案 


系统 中 的 “资料 来 , 没 两 榜 。 简 单 来 说 ，tree 
物件 这 就 是 在 特定 版 本 下 某 个 资料 来 的 快照 

(Snapshot)。 
.Commit 物件 : 用 来 记 杀 有 哪些 tree 物件 包含 
在 版 本 中 ， 一 个 commit 物件 代表 著 Git 的 一 
次 提交 ， 记 销 著 特定 提交 版 本 有 哪些 tree 物 
件 、 以 及 版 本 提交 的 时 间 、 纪 杀 讯息 等 等 ， 通 
常 迁 会 记 销 上 一 层 的 commit 物件 名 称 (只 有 第 
一 次 commit 的 版 本 没 有 上 属 commit 物件 名 
称 。 
tag 物件 : 是 一 个 容器 ， 通 常用 来 关联 特定 一 
个 commit 物件 (也 可 以 关联 到 特定 blob、tree 
物件 )， 下 额外 储存 一 些 额 外 的 参考 资讯 
(metadatal)， 例 如 : tag 名 称 。 使 用 tag 物件 最 
常见 的 情况 是 蔡 特 定 一 个 版 本 的 commit 物件 
标示 一 个 易 懂 的 名 称 ， 可 能 是 代表 某 个 特定 发 
行 的 版 本 ， 或 是 所 有 某 个 特殊 意义 的 版 本 。 


CD 


> 


Git 会 将 每 一 个 版 本 中 的 档案 建立 一 个 对 应 的 blob 
物件 ， 一 样 的 ， 该 blob 物件 的 档 名 就 是 用 上 述 的 方 
式 计算 出 来 的 ， 和 从 这 些 blob 档案 ， 你 看 不 出 跟 版 本 
有 任何 关 傈 ， 你 必须 透 过 tree 物件 (资料 夹 的 快照 ) 
与 commit 物件 (每 一 个 版 本 的 快照 ) 才能 关联 出 这 
些 blob 与 版 本 的 关 傈 。 


所 有 的 物件 都 会 以 zlib 演算 法 进行 压缩 ， 不 但 可 以 
有 效 的 提升 档案 存 取 效 率 ， 在 日 后 进行 封装 (pack) 
的 时 候 也 可 以 利用 差 轴 屡 缩 (delta compressiom) 演 
算法 来 节省 空间 。 他 会 自动 找 出 相似 的 blobs， 半 
自动 计算 出 blob 之 问 的 释 化 差 虹 ， 再 将 这 些 差 黑 储 
存在 一 个 名 为 packjje 的 档案 中 ， 这 样 就 可 以 大 幅 
节省 磁 碟 空间 的 耗 用 )。 通 党 packHjjje 会 置 座 .git 
\objects\pack 目录 下 ， 如 下 图 示 : 


” git-demo ，.git ”objects ”pack 
^ 名 区 
局 pack-2769e99412e399985ddbca4e0efda776648159b4.idx 
砷 pack-2769e99412e399985ddbca4e0efda776648159b4.pack 


人 


上 述 这 四 种 物件 之 问 的 关 傈 ， 可 参考 以 下 图 示 : 


然而 ， 光 是 观看 文字 与 图 示 ， 或 许 还 是 难以 看 出 这 

做 种 物件 类 型 之 问 的 关 傈 ， 没 关 傈 ， 笔 者 特别 录 秽 

了 一 段 教学 影片 ， 试 图 用 git 指令 的 方式 解释 Git 的 
物件 结构 与 产生 物件 的 过 程 ， 也 让 各 位 更 清楚 的 了 

解 到 底 Git 如 何 产生 和 与 管理 这 些 档案 。 


YouTube 影片 连 结 : 认识 Git 资料 结构 中 的 物件 资 
料 库 与 物件 之 问 的 关 体 


物件 结构 的 优 骂 


你 应 该 可 以 渐渐 了 解 Git 的 “物件 ， 设计 是 如 此 的 

票 亮 ， 我 们 在 第 一 篇 文章 曾经 提 到 绑 个 Git 重要 的 
设计 我 们 重新 列 出 做 点 与 【物件 ， 特性 有 关 的 设 
计 来 看 看 : 


。 有 效率 的 处 理 大 型 专案 


过 不 二 全 下 下 各 民 放 作 人 人 份 
在 本 机 ， 由 於 所 有 的 blob 物件 都 是 透 过 
内容 ， 来 做 定 址 的 (content 
addressable)， 因 此 ， 和 若 在 不 同 版 本 之 间 
找寻 相同 的 内 容 ， 效 率 是 非常 高 的 。 
。 历史 纪 杀 保护 


O Git 版 控 的 过 程 ， 每 次 提交 继 更 都 会 产生 
一 个 commit 人 而 这 个 commit 物件 
的 名 称 又 是 透 过 commit 物件 的 内 容 彦 
生 。 再 者 ，commit 物件 会 关于 到 tree 物 
件 ，tree 物件 的 名 称 又 是 透 过 tree 物件 的 
内 容 所 产生 。tree 物件 又 会 关联 到 blob 
与 tree 物件 ， 这 些 物 件 的 名 称 也 是 透 过 内 
容 彦 生 。 就 这 样 一 层 一 层 的 关联 下 去 ， 如 
果 你 今天 真 的 想 埠 改 某 个 版 本 的 历史 纪 
杀 ， 因 准 度 也 是 挺 高 的 ! 


O 由 於 Git 储存 库 经 常会 被 clone 或 fork ， 


只 要 是 被 clone 过 的 储存 库 ， 来 源 的 储存 
库 只 要 任何 一 个 物件 被 修改 ， 这 些 clone 
出 去 的 储存 库 就 很 杂 再 合 供 回 来 ， 所 以 你 
作 乎 不 可 能 任意 蚌 改 版 本 纪 针 。 


。 定 期 的 封装 物件 


O 〇 


O 


我 们 在 Git 中 提 到 的 "物件 " 其 实 就 是 代表 
版 本 库 中 的 一 个 档案 。 而 在 版 本 典 动 的 过 
程 中 ， 专 案 中 的 程式 码 或 其 他 档案 会 被 更 
新 ， 每 次 更 新 时 ， 只 要 档案 内 容 不 一 样 ， 
就 会 建立 一 个 新 的 "物件 "， 这 些 不 同 内 容 
的 档案 全 部 都 会 保留 下 来 。 

你 应 该 可 以 想像 ， 当 一 个 专案 越 来 越 大 、 
版 本 越 来 越 多 时 ， 这 个 物件 会 越 来 越 多 ， 
只 然 每 个 档案 都 可 以 各 自 灰 缩 让 档案 释 
小 ， 不 过 过 多 的 档案 还 是 会 档案 存 取 释 得 
越 来 越 没 效率 。 因 此 Git 的 设计 有 个 机 制 
可 以 将 一 群 老 苗 的 "物件 " 自动 封装 进 一 个 
封 于 杭 (packfile) 中 ， 以 改善 榴 案 存 取 效 
那些 新 增 的 档案 逮 是 会 以 单一 档案 的 方式 
存在 著 ， 也 代表 一 个 Git 版 本 库 中 的 " 档 
案 " 就 是 一 个 Git "物件 "， 但 每 隔 一 段 时 间 


就 会 需要 重新 封装 (repacking)。 

O 〇 照 理 说 Git 会 自动 执行 重新 封装 等 动作 ， 
但 你 依然 可 以 自行 下 过 指令 执行 。 例 如 : 
git gc 

〇 O 如 果 你 要 检查 Git 维护 的 档案 系统 是 否 完 
整 ， 可 以 执行 以 下 指令 : git fsck 


今日 小 给 


Git 里 的 物件, 十 分 重要 ， 其 特性 也 十 分 重要 ， 内 
然 我 们 在 操作 Git 指令 的 过 程 中 通常 不 太 需 要 直接 
接触 这 些 档案 ， 不 过 了 解 这 些 物件 的 存在 ， 也 确实 
有 助 认 让 你 更 加 理解 Git 的 运作 模式 ， 和 与 Git 独到 
的 设计 概念 。 


参考 连结 


。 Git Internals - Git Objects 

。 Pro Git Book 

。Git Magic - 繁体 中 文 版 

。 Git (Software) - Wikipedia, the free 
encyclopedia 


*。 HOME 


。 回 目录 
。 前 一 天 : 了 解 储存 库 、 工 作 目 录 、 物 件 与 索引 
之 问 的 关 傈 


。 下 一 天 : 解析 Git 资料 结构 - 索引 结构 


第 07 大 : 解析 Git 资料 结构 
- 系 5| 和 结构 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/07.md 


我 们 知道 在 Git 里 两 个 重要 的 资料 结构 ， 分 别 是 
物件， 与 “索引 ，， 这 篇 文章 主要 用 来 解说 这 
引 J 的 细节 。 使 用 Git 版 本 控 管 的 过 程 中 ， 或 许 你 
可 以 很 轻易 的 了 解 git 指令 的 用 法 ， 不 过 那 很 容易 
流 於 死记 ， 无 法 圳 活 运 用 ， 囊 Linus Torvalds 都 在 
邮件 清单 (Mailing List) 中 提 到 : “在 使 用 者 了 解 索 
引 的 意义 之 前 ， 是 无 法 完整 了 解 Git 的 能 力 的 ，， 
因此 ， 了 解 “ 索 引 , 的 用 途 十 分 重要 。 


关於 宗 5| 


简单 来 说 ，' 这 引 , 的 目的 主要 用 来 纪 杀 ' 有 哪些 
当 案 即将 要 被 提交 到 下 一 个 commit 版 本 中 , 。 


换 句 话说 ，" 如 果 你 想 要 提交 一 个 版 本 到 Git 储存 


库 ， 那 床 你 一 定 要 先 更 新 索引 状态 ， 释 更 才 会 被 提 
芝山 去 ca 


这 壬 的 “索引 其 实在 国外 很 多 文章 和 里 曾经 出 现 过 
很 多 别名 ， 但 其 意思 都 是 相同 的 ， 各 位 以 后 看 到 相 
关 单 子 千 万 不 要 被 混 清 了 。 


。 |ndex (索引 ) 

。 Cache ( 快 取 ) 

。 Directory cache ( 目 杀 快 取 ) 

。Current directory cache (当前 目 销 快 取 ) 
。 Staging area (等 待 被 commit 的 地 方 ) 

。 Staged files (等 待 被 commit 的 档案 ) 


浴 个 例子 来 说 ， 指 令 sit diff --cached 就 
熏 dit diff --staged 是 完全 同 义 的 。 
操作 么 引 的 指令 


由 於 "索引 对 Git 来 说 十 分 重要 ， 在 大 多 数 的 指 
令 中 都 会 有 跟 Git 康 引 相关 的 参数 可 用 ， 不 过 我 们 
大 致 列 出 绑 个 直接 与 索引 , 相关 的 指令 来 解说 。 


在 解说 指令 之 前 ， 各 位 可 以 先 看 看 以 下 示意 图 ， 
说 明了 透 过 指令 改 释 状态 的 生命 遇 期 ， 事 实 上 ， 


种 f 冲 


些 改 变 的 过 程 ， 都 是 在 更 新 乏 引 档 , 的 过 程 : 


File Status Lifecycle 


首先 ， 先 介绍 四 种 档案 状态 : 


。uUntracked (未 追 跳 的 ， 代 表 尚 未 被 加 入 Git 储 
存 库 的 档案 状态 ) 

。unmodified (未 修改 的 ， 代 表 档 案 第 一 次 被 加 
入 ,或 是 档案 内 容 与 HEAD 内 容 一 致 的 状态 ) 

。modified (已 修改 的 ， 代 表 档 案 已 经 被 编辑 过 ， 
或 是 档案 内 容 和 与 HEAD 内 容 不 一 致 的 状态 ) 

。Sstaged (等 待 被 commit 的 ， 代 表 下 次 执行 git 
commit 会 将 这 些 档案 全 部 送 入 版 本 库 ) 


git status 


取得 工作 目录 (working tree) 下 的 状态 。 


由 於 先前 已 经 讲 过 储存 库 、 工 作 目 朱 、 物 件 与 索引 
之 问 的 关 傈 ， 我 们 用 一 句 话说 明 这 关 信 : 


Git 储存 库 的 运作 ， 是 将 工作 目 凶 里 的 释 化 ， 透 过 更 新 索 引 的 方 


这 里 的 9it status 指令 ， 目的 是 显示 出 目前 最 新 
版 与 索引 档 之 问 的 差 吐 ， 这 当中 的 差 时 包含 了 一 
些微 妙 的 关 休 ， 我 们 用 一 个 例子 来 解释 这 层 关 人 。 


以 下 是 执行 git status 的 结果 : 
:Ngit-dqemo>dgit status 
On branch masteL 
Chandges to be committed : 
(use "dit reset HEAD <file>..."to unstade) 


new file: @ 晤 | 


@hangss 有 TOESEE3geGEEoEeommaic 


(use "gjit add <file>..." to update what WILL 
(SECEGKEORNEE 二 < 人 IE EC 避 arzaQ 
moqified: ED 


砷 砷 : 砷 坤 : 霜 填 砷 填 砷 : 坤 井 井 由 


浊 本 呵 页 二 二 二 全 帮 E 本 站 二 证 es 


非 (seamvone 本 sq 县 < 这 ECOTTmCTUE 二 al whnat 
非 
非 1 


这 里 你 会 看 到 有 三 种 不 同 的 分 组 ， 分 别 是 : 
。Changes to be committed (准备 提交 的 继 更 ) 


C 〇 这 区 有 个 new file: C. 七 Xt 档案 代表 
c.txt 是 一 个 新 枚 案 ， 而 且 已 经 被 标示 可 提 


O 


交 
〇 这 代表 著 绑 件 事 : 


1. 目前 最 新 版 下 没有 c.txt 这 个 档案 
2. 索引 档 已 经 加 入 了 这 个 c.txt 档案 
3. 所 以 该 档案 会 在 执行 gt commit 之 后 
被 存 入 下 一 个 版 本 
。 Changes not staged for commit (尚未 准 人 备 提 


交 的 变更 ) 


O 〇 O 这 区 有 个 moaifieda: a.txt 档案 ， 代表 
a.txt 已 经 被 变更 ， 但 尚未 标示 可 提交 。 
(not staged) 

〇 这 代表 著 绑 件 事 : 


1. 目前 最 新 版 也 有 a.txt 这 个 档 
2. 索引 档 尚未 加 入 a.txt 这 个 档 
3. 所 以 该 档案 就 算 执 行 了 git commit 也 
不 会 在 下 一 版 中 出 现 
。 Untracked files (未 追 跳 的 变更 ) 


泣 测 


〇 这 区 有 个 b.txt 档案 ,代表 b.txt 尚未 被 
追 跳 。(untracked) 


O 这 代表 著 几 件 事 : 


1. 目前 最 新 版 没有 b.txt 这 个 档案 

2. 么 引 档 也 没有 b.txt 这 个 档案 

3. 所 以 该 横 案 融 算 执行 了 git commit 也 
不 会 在 下 一 版 中 出 现 


所 以 你 可 以 看 到 ， 执 行 git status 就 是 为 了 查 出 目 
前 最 新 版 生 索引 档 之 问 的 差 蛙 ， 最 终 只 有 目前 最 
新 版 且 索引 档 之 间 有 差 轩 的 变更 ， 才 会 真正 储存 
到 下 一 个 commit 物件 里 。 


git add 


sit ada 指令 , 是 为 了 将 目前 “工作 目 朱 ， 的 变 
写 入 到 5 索引 档 ， 和 里 。 


使 用 sit ada -u 则 可 以 仅 将 更新: 或 “删除 ， 
的 档案 释 更 写 入 到 索引 档 ,， 中 。 


dgit rm 


我 们 以 sit rzm 为 例 ， 当 你 直接 在 档案 系统 中 删除 
一 个 档案 ， 这 只 是 从 "工作 目 录 ， 中 删除 而 已 ， 半 
没有 更 新 到 索引 档 ， 你 可 以 利用 git status 看 到 这 属 
改变 ， 不 过 若 要 真正 把 " 删除, 的 状态 写 进 索引 档 
的 话 ， 则 要 靠 sit rm filename 更 新 索引 档 。 


在 执行 git rm filename 的 时 候 ， 除了 更 新 索引 档 
之 外 ， 堪 工作 目录 下 的 档案 也 会 一 供 被 删除 。 若 你 
只 想 删 除 系 引 横 中 的 该 榴 ， 又 要 保留 工作 目 色 下 的 
实体 档案 ， 那 么 你 可 以 在 指令 列 加 上 --cachead 参 
数 ， 就 能 做 到 ， 例 如 : 


esima cachis 昌 划 a 汪 ER 


dgit mv 


使 用 9it mv oldname newname 可 以 将 当 案 更 名 
执行 此 命令 会 同时 更 新 索引 与 变 更 工作 目 杀 下 的 实 


品 曲 PL5 一 
体 档 案 。 


git commit 


这 个 指令 ， 则 是 把 上 “索引 档 ,， 熏 "目前 最 新 版 ， 中 
的 资料 比 对 出 差 黑 ， 然 后 把 差 黑 部 分 提交 释 更 成 一 
个 commit 物件 。 


dgit ls-files 


在 索引 档 之 中 ， 预 设 就 包含 了 目前 最 新 版 的 所 有 档 
案 ， 外 加 你 在 工作 目录 中 新 增 档案 且 透 过 sit adq 
更 新 京 引 档 和 后 的 那些 档案 。 透 过 sit 1s-files 命 
令 ， 可 以 列 出 所 有 目前 已 经 储存 在 索引 档 , 中 的 


那些 档案 路 径 。 


从 如 下 图 范例， 你 应 该 可 以 看 出 这 做 个 指令 之 问 的 
关公 : 


:Ngit-demo>git Status 
悍 On branch master 
悍 Changes not Staged for commit: 
《use "qit add 《file>-.--" to update what will be committed> 
《use "qit checkout --《file>.--" to discard changes in wokking directory) 


眉 Untracked files: 
《use "glit add 《file>.--." to include in what will he committed> 


0 changes addqded to commit 《use "git adqd'" andAor "9git commit 一 a"》 


:Ngit-demo>git 1s-files 
-七 Xt 


:Ngit-demo>git aqd - 


:Ngit-demo>git 1s-files 
-七 Xt 
七 Xt 
-七 Xt 


:Ngit-demo>git status: 
悍 On branch master 
尾 Changes to be committed: 
《use "git keset HERD 《file>--.--" to unstage)> 


今日 小 结 


Git 里 的 “这 引 , 是 Git 版 控 中 最 重要 的 必 念 ， 有 了 
这 层 必 念 ， 也 自然 能 得 知 ， 和 为 什么 每 次 提交 释 更 都 
要 打 一 些 指令 把 继 更 给 加 人 进去。 当然 ， 也 有 许多 好 
用 的 GUI 工具 可 以 旭 你 少 打 许 多 指令 ， 不 过 在 我 们 
正式 开始 使 用 Git 的 GUI 工具 之 前 ， 我 们 还 是 多 靠 
指令 把 观念 给 建立 再 说 吧 ! 


考 和 过 结 


巾 


the Git Index? - GitGuys 
。Git - Recording Changes to the Repository 
。 Pro Git Book 
。Git Magic - 繁体 中 文 版 
。 Git (Software) - Wikipedia, the free 
encyclopedia 


。 HOME 

。 回 目 凶 

。 前 一 天 : 解析 Git 资料 结构 - 物件 结构 

。 下 一 天 : 关於 分 支 的 基本 观念 与 使 用 方式 


第 08 大 : 关於 分 支 的 基本 现 
念 与 使 用 方式 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/08.md 


在 Git 里 面 分 支 (Branch) 是 个 非常 重要 的 机 制 ， 使 
用 上 也 必须 特别 小 心 ， 因 入 吉 案 总 不 能 乱 限 制 的 
-分支 4 下 去 ， 最 终 总 是 要 合 们 的 ， 但 合 供 是 日 后 
的 议题 ， 这 篇 文章 将 会 先 带 大 家 学 会 Git 分 支 基本 
观念 与 使 用 方式 。 


关於 分 文 的 基本 凋 念 


在 版 本 控 管 中 使 用 ' 分 支 : 机 制 ， 最 主要 的 目的 就 
是 用 来 解决 开发 过 程 中 版 本 衢 突 的 问题 。 笔 者 说 

为 ， 有 许多 曾经 用 过 任何 版 本 控 管 机 制 的 人 ， 都 会 
认为 "分 支 ! 是 个 "产生 版 本 征 突 , 的 元 铝 ， 因 为 
当 你 开始 分 支 之 人 后， 一定 就 会 想到 合 供 的 议题 ， 而 
当 分 支 之 后 ， 和 若是 有 人 跟 你 一 样 修改 到 相同 档案 的 
相同 一 行 时 ， 就 会 引发 版 本 衢 突 ， ， 而 只 要 发 生 


征 突 ， 就 必须 导 心 解决 。 


当 衢 突 发 生 时 ， 有 时 可 以 很 轻易 的 决定 要 用 自己 的 
版 本 或 是 对 方 的 版 本 ， 但 有 时 邹 没 那 床 容 易 ， 复 杂 
的 时 候 还 要 依据 衢 突 的 片段 ， 找 到 当初 改过 这 做 行 
的 人 出 来 ， 协 调 出 彼此 的 变更 对 系统 的 影响 ， 最 后 
决定 要 怎样 合 任 ， 诸 如 此 类 的 问题 非常 繁 玉 ， 也 因 
此 很 多 人 会 尽力 避免 分支: 的 情况 发 生 ， 以 免费 
生 " 衢 突 , 。 


不 过 ， 知 是 开发 围 队 越 来 越 大 ， 系 统 功能 越 来 越 
多 ， 就 算 你 不 对 版 本 做 分 支 ， 大 家 的 种 突 情况 一 柑 
也 会 层 出 不 雳 ， 有 时 候 还 不 是 征 突 的 问题 ， 而 是 A 
写 好 一 个 功能 ， 但 被 B 的 和 后续 版 本 给 一 把 了 ， 然 后 
没有 任何 征 突 发 生 ， 这 也 不 是 大 家 所 乐 见 的 。 然 
而 ， 这 也 是 一 种 ' 无 形 的 备 突 , 状 沉 。 


以 前 在 集中 管理 的 Subversion 版 控 机 制 中 ， 也 有 分 
支 的 概念 ， 也 可 以 运作 的 很 好 。 当 然 ， 如 果 你 的 软 
体 架 构 不 多 好 ， 如 果 你 对 分 支 的 概念 、 工 具 的 使 用 
也 不 是 很 清楚 ， 我 相信 使 用 分支, 时 也 不 会 多 顺 
利 ， 这 是 个 必然 的 结果 ， 这 世界 绝 不 会 有 " 免 学 、 
无 痛 、 自 然 学 会 分 支 , 的 这 种 版 本 控 管 工具 出 现 ， 
事在人为 ， 人 的 观念 不 对 ， 用 什么 工具 都 不 会 顺 


的 。 


由 於 Git 属於 "分散 式 版 本 控 管 机 制 ， ， 在 分 散 式 
版 本 管理 的 使 用 情境 中 ， 最 不 想 做 的 事情 就 是 ' 管 
理 ， ， 所 以 Git 很 少 有 所 谓 的 管理 机 制 或 权限 控 管 
机 制 ， 它 唯一 想 做 的 仅仅 是 让 大 家 可 以 顺利 的 “分 
支 ! 与 ' 合 伴 ， 而 已 。 


我 们 以 【第 03 天 : 建立 储存 库 】 这 篇 文章 提 到 的 
和 踪 端 的 储存 库 (remote repository) , 为 例 ， 你 可 
以 这 样 想像 : 从 我 们 使 用 sit clone 指令 开始 ， 其 
实 就 是 ' 分支: 的 开始 ， 你 从 还 端 储存 库 复 移 一 份 
完整 的 储存 库 下 来 ， 然 后 开始 在 自己 的 本 地 端 建立 
版 本 ， 等 软体 修订 到 一 定 程度 后 再 " 合 伴 , 回去 ， 
只 是 这 时 合 供 的 指令 叫做 sit pusnh 而 已 。 


这 种 分 支 与 合 供 的 情形 ， 在 Git 版 本 控 管 的 过 程 中 
无 所 不 在 ， 这 端的 储存 庆 可 以 有 分 文 ， 本 地 的 储存 
库 可 以 有 分 支 ， 你 可 以 从 下 端 任何 一 个 分 支 合 儒 
(pull) 到 本 地 分 支 ， 也 可 以 将 本 地 的 分 支 推 向 (push) 
还 端 的 分 支 ， 你 当然 也 可 以 从 本 地 任何 一 个 分 支 合 
供 (merge) 到 本 地 的 另 一 个 分 广 。 可 以 想见 ， 如 果 
[分支 : 没有 一 套 良 好 的 控 管 选辑 ， 最 后 可 以 组 合 
出 各 种 极其 复杂 的 版 本 控 管 使 用 情境 ， 这 也 不 是 大 


家 所 乐 见 的 。 因 此 ， 好 好 学 会 分支 ! 与 ' 合 供 ， 
真 的 非常 重要 。 例 如 git-flow 就 是 一 套 广 受 欢 迎 的 
分 支管 理 模式 ， 这 不 是 一 套 工 具 ， 而 是 一 种 管理 分 
支 的 选辑 ， 这 部 分 在 我 未 来 的 文章 中 将 会 加 以 褒 
明 。 


Linux kernel 发 展 的 过 程 ， 在 全 世界 有 成 千 上 万 的 
并 发 人 员 共 同 参 与 ， 为 了 管理 这 育 大 量 的 开发 转 

队 ，Git 估 然 而 生 ， 这 是 套 分 散 式 的 版 控 机 制 ， 每 个 
人 都 有 完整 的 版 本 ， 版 本 散 出 去 之 后 ， 大 家 必须 管 
好 自己 的 版 本 ， 然 后 遵照 园 队 的 要 求 合 人 屏 回来。 然 
而 ， 在 合 儒 回 来 之 前 ， 这 套 机 制 确 保 每 个 人 都 能 狗 
顺利 的 开发 ， 不 受 任何 其 他 开发 人 员 的 版 本 而 影 

冤 ， 而 Git 确实 做 到 了 这 点 ,同时 又 降低 了 版 本 控 
管 的 复杂 度 。 


当然 ， 我 也 必须 讲 ， 如 果 参 与 软体 开发 的 转 队 只 
两 三 人 ， 而且 这 些 人 还 都 聚 在 一 起 ， 那 确实 不 一 定 
要 使 用 Git 版 本 控 管 ， 使 用 Subversion 也 是 个 很 好 
的 园 择 ， 简 单 又 直 攻 ， 开 发 的 过 程 中 若 遇 到 问题 ， 
前 后 左右 协调 一 下 就 能 解决 ， 这 比 让 整个 转 队 都 来 
了 解 Git 来 的 方便 很 多 。 


如 果 你 的 围 队 有 点 规模 ， 或 大 家 站 疫 有 坐 在 一 起 工 


作 ， 又 要 做 版 本 控 管 的 话 ， 或 许 Git 是 个 不 错 的 选 
择 ， 但 工作 围 队 之 问 拨 有 一 致 的 版 控 观 念 或 习惯 ， 
也 是 非 党 重要 的 一 件 事 。 


准 位 工作 目 色 


我 们 透 过 以 下 指令 快速 建立 一 个 所 有 两 个 版 本 的 Git 
储存 库 与 工作 目 凶 : 


mkadir g9it-branch-dqaemo 
cd2gdit=braneh=denma 

asiaiie 

二 

GEESdOd 

Gamma molesieaEeemmaalsee 
人 


GeEEiere 


GeEeemmaiem 和 本 于 宝 ES 全 和 COmieeint 


接著 使 用 sit 1los 取得 版 本 资讯 如 下 : 


CNdqemoNgit=branch=-aQemo>git 1og 


commit bpb917758c0f2f347a895ee5pbbb5e5c8228f66335a 
AuEneoe 遇 人 梧 可 必 <oegogogysnuangkomaaajescom> 
Date : Ce 区 0 瑟瑟 0S00 


EUEodERISLEIGIEEISLeoioEEiOE 


commit aa3e4fe2ee065b046e00a74b1l1f1l2a0b0f8154003 
六 Enen 人 本 可 和 eooggysnaanogomaaalesceomz: 
Date : IO 人 狂人 0 


masceciEcomma 巧 


接著 我 们 透 过 sit brancnh 指令 得 知 我 们 已 经 拥有 
一 个 名 为 master 的 分 支 ， 这 是 在 Git 储存 库 中 的 

预 设 分 文 。 如 果 你 芝 试 透 

过 9it branch -qdq masteL 删除 这 伯 分 支 7 将 会 得 

到 error: Cannot delete the branch "master' which 
的 错误 讯息 ， 这 意思 是 ' 当 你 目前 工作 目录 分 支 设 

定 为 master 时 ， 不 能 删除 目前 这 个 分 文 ; ， 也 就 

是 说 ， 你 必须 先 切换 到 "其 他 分 支 : 才能 删除 这 个 

分 闵 。 


本 命令 提示 字 元 


:NduemoNgit-hbranch-demo>gqit branch 


ekrkor: Cannot delete the branch :master”′ which you are cuFrently on- 


| 
:NduemoNgit-hbranch-dqemo>git branch -Qdq mastekr 


量 然 ， 我 们 现在 只 有 一 人 分 支 ， 目 然 扰 法 删除 自 
己 。 


建立 分 支 
建立 分 支 最 常见 有 两 种 方法 ， 分 别 是 : 


1. 建立 分 文 ， 但 目前 工作 目 凶 维持 在 目 己 的 分 


建 
支 : 9it branch [BranchName] 


当 我 执行 sit branch newbranchl 指令 ， 这 
会 建立 一 个 新 的 newbranchl 分 支 ， 我 们 接著 
用 sit branch 查看 目前 有 多 少 分 支 ， 你 会 
到 两 个 ， 但 目前 工作 目录 还 会 停留 在 master 
分 文 上 ， 如 下 图 示 : 


如 果 这 时 你 在 目前 的 工作 目 杀 建立 版 本 ， 这 时 
会 建立 在 masS 七 eI 分 支 里 面 7 我 们 这 时 建立 一 
个 新 档案 ， 半 且 透 过 sit commit 建立 版 本 ， 
目 令 如 下 


echo master > bp. 七 X 七 


可 JE 二 Ooq 


gcommo 三 ma CE 是 WECOnmieEnt 


请 先 记得 ; 我 们 先 在 预 设 的 master 分 支 建立 
两 个 版 本 ， 然 后 建立 一 个 分 文 ， 然 后 
在 masteL 分 支 又 建立 了 一 个 版 本 。 


. 建立 分 文 ， 亚 将 目前 工作 目 公 切换 到 新 的 分 


支 : 9it checkout -b [BranchName] 


接 下 来 ， 我 们 用 第 二 种 方法 建立 分 支 ， 沼 我 执 
行 git checkout -b newbranch2 指令 ， 不 但 
会 建立 一 个 新 分 支 ， 膛 会 将 目前 工作 目 销 切换 
到 另 一 个 分 支 ， 最 后 用 sit branch 查看 目前 
有 多 少 分 支 ， 你 会 看 到 已 经 有 三 个 ， 而 且 目 前 
工作 目 色 已 经 切换 到 刚刚 建立 的 newbranch2 

分 广 上， 如 下 图 示 : 


本 命令 提示 字 元 


如 果 这 时 你 在 目前 的 工作 目 杀 建立 版 本 ， 过 时 


会 建立 在 newbranch2 分 支 壬 面 ， 我 们 这 时 建 
立 一 个 新 当 案 7 普 且 透 过 9it commit 建立 版 
本 ， 指 令 如 下 : 


echo newbranch2 > pb. 七 X 上 
可 工 要 芋 吉 可 全 由。 


gcCOmimae 本 出 全 MewRRY ED 天 坟 世 WOMIEED 七 “ 蕊 


请 记得 : 我 们 先 在 预 设 的 master 分 文 建 立 两 
个 版 本 ， 然 合 建立 一 个 分 广 ， 然 后 在 master 
分 支 又 建立 了 一 个 版 本 ， 接 著 又 把 当下 这 

份 master 分 支 的 状态 建立 一 个 新 

的 newbranch2 分 支 ， 芷 将 工作 目 凶 到 切换 
到 newbranch2 分 广 ， 然 后 再 建立 一 个 唉 本 。 
我 们 这 时 如 果 执 行 sit 1los 会 显示 出 4 个 版 
本 纪 从 “， 因 为 分 支 会 自动 继承 来 源 分 支 的 完整 
历史 。 


goesbEanchnalorcsnchmameil 


切换 分 文 


如 果 你 想 将 工作 目 凶 切换 到 其 他 分 支 ， 你 可 以 输入 
以 下 指令 (不 含 -b 参数 ) : 


9it checkout [bzanch_name] 


假设 我 们 想 把 工作 目 销 切换 到 newbranchl 分 支 ， 
这 时 可 以 输入 ggit checkout newbranchl 切换 过 
去 ， 然 后 你 可 以 立刻 使 用 sit branch 检查 目前 工 
作 目 销 是否 切 换 过 去 ， 然 后 再 用 sit 1og 检查 浊 

下 _ newbranchl 分 支 的 历史 纪 杀 。 因 为 这 是 我 们 第 
一 次 建立 的 分 支 ， 照 理 褒 这 伯 分 支 状 态 应 该 只 会 有 
两 笔 历 史 纪 从 而 已 ， 如 下 图 示 : 


:NduemoNgit-hbranch-demo >git checkout newhbranchil 
必 witched to branch ”newhbranchi” 


:NduemoNgit-hbranch-demo>git branch 
mastek 


newhbranch2 
:XemoNgit-hbranch-demo>git 1og 


huthor: Will 《doggy.huangegmail.com> 
Date : Fri Oct 4 209:58:16 2013 +0860 


a-txt: Set 1 as content 


uthor: Will 《doggy-huangegmail.-comy> 
Date : Eri Oct 4 29:094:39 20913 +9899 


Initial commit 


: 详细 的 指令 与 参数 说 明 ， 可 以 坦 


9it helP checkout 查询 完整 的 文件 。 


> 合 


9it checkout [branch_name] 


删除 分 支 
如 果 你 想 删除 现 有 的 分 支 ， 就 如 同 我 们 在 准备 工作 
目 朱 有 提 到 过 的 指令 ， 如 下 : 


geesborcancha=aaliiorancnEnanmei 


先前 也 有 提 到 ， 你 不 能 删除 目前 工作 目 色 所 指定 的 


分 支 ， 必 须 先 切 换 到 其 他 分 支 人 后， 再 删除 你 目前 这 
1 浴 个 例子 来 说 ， 如 果 你 想 删 除 党 下 这 

个 newbranchl 分 文 ， 那 床 你 必须 先 切 换 到 其 他 分 
支 ， 例 如 mastez 分 支 ， 然 后 再 下 

达 sit branch -ad newbranchl 指令 ， 即 可 删除 分 


支 ， 如 下 图 示 : 


:NiemoNgit-hbranch-demo>git branch 
master 


newhbranch2 


:NdemoNgit-branch-demo >git checkout master 
朴 witched to branch master” 


:NiemoNgit-hbranch-demo>gqit branch -dd newhbranchi 
peleted branch newhbranchl 《was hb917?7?7587). 


:NduemoNgit-hbranch-demo >git hbranch 


newhbranch2 


查看 工作 目 人 在 哪个 分 文 


你 可 以 透 过 9it pranch 命令 7 查看 目前 所 在 分 
文 ， 如 下 图 示 : 


:NdemoNgit-hbranch-demo>git branch 
newhbranch2 


:NdemoNgit-hbranch-demo>git checkout newhbranch2 
枚 witched to branch :newhbranch2” 


:NiemoNgit-hbranch-demo>gqit branch 


maste 


:NdemoNgit-hbranch-demo>gqit Status 
悍 On branch newhbranch2 


othing to commit 。 wokking directoFry clean 


查看 Git 储存 库 的 元 整 分 文 图 


最 人 后， 我 用 SourceTree 工具 来 显示 目前 Git 储存 
库 的 分 支 图 。 目 前 我 们 只 有 两 个 分 文 ， 一 个 

是 maste 工 分 支 7 另 一 个 是 newbranch2 分 支 7 
入 newbranchl 分 文 已 经 在 练习 的 过 程 中 被 删除 
了 。 义 了 要 让 我 们 的 分 广 有 树 状 , 的 感 反 ， 接 下 
来 我 要 示范 如 何 重 新 建立 一 个 与 先前 newbranchl 
一 样 状 态 的 分 支 ， 下 且 在 这 个 分 支 下 加 入 一 个 新 版 
站 


不 知道 各 位 膛 记 不 记得 ， 我 们 是 在 master 分 支 建 
立 两 个 版 本 和 后 才 建立 newbranchl 分 支 的 ， 现 在 我 
们 就 先 找到 到 这 个 版 本 的 commit 物件 id， 透 

过 sit log 即 可 取得 ， 如 下 图 示 : 


:NdemoNgit-hbranch-demo>gqit checkout master 
枚 witched to branch master 


:NduemoNgit-hbranch-demo >git 1og 


huthor: Vill 《doggy-huangegmail.comy> 
IDpate : Fri Oct 4 21:12:15 20913 +0809 


Create b.txt with content "mastekr” in the mastekr branch 


huthor: Vill 《doggy-huangegmail.-com> 
IDpate : Fri Oct 4 29:58:16 20913 +0809 


atxt: Set 1 as content 


huthor: Will 《doggy-huangegmail.comy> 
IDate : Fri Oct 4 29:094:3?9 2013 +09809 


Initial commit 


所 以 我 的 commit 物件 id 为 : 
b917758c0Of2f347a895ee5bbb5e5c8228f66335a 


接著 我 先 把 工作 目 人 录 切换 到 这 个 版 本 ， 
过 glit checkout [commit_idj] 有 言 个 任 


务 : 


9it checkout b917758c0f2f347a895ee5bbbD5e5c8228f6 


这 时 你 用 sit 1og 应 该 只 会 看 到 两 个 版 本 纪 色 而 
已 ， 因 为 我 们 已 经 把 工作 目 俏 的 状态 切换 成 这 个 版 
本 了 。 和 从 下 图 可 以 看 到 我 们 执 


行 9it checkout pb917758c0f2f347a895ee5bbpb5eD5c8228f 


寺 会 出 现 一 对 讯息 ， 这 些 讯 息 很 重要 ， 必 须 了 解 一 
下 ， 如 下 图 示 : 


:NdemoNgit-hbranch-demo >git checkout b9?17?758cBf2f34?7a895ee5hbhbb5e5c8228f66335a 
: checkil out ”hb9?17758cgBf2f347a895ee5hbhbhb5e5c8228f66335a”- 


d。make experimental 
its you make in this 


ain commits you cFeate。 you may 
e checkout command again 。Example: 


oOw at hb917?7758..。a-txt: S 


Ithor: Will 《doggy.huangegmail.com> 
Fri Oct 4 29:58:16 2913 +9899 


: Set 1 as content 


上 uthor: Will 《doggy-huangBegmail.com> 
Fri Oct 4 29:94:39 2913 +9869 


Initial commit 


首先 ， 由 於 你 将 工作 目 销 的 版 本 切换 到 上 得 的 , 版 
本 ， CE 佳 入 了 所 谓 
的 detached HEAD 状态 ， 这 是 一 种 "目前 工作 目 
凶 不 在 最 新 版 ， 的 提示 ， 你 可 以 随时 切换 到 Git 储 
存 库 的 任意 版 本 ， 但 是 由 於 这 个 版 本 已 经 有 上 下 一 
版 ， 所 以 如 果 你 在 目前 的 上“ 竹 版 ， 执 

行 sit commit 的 话 ， 就 会 导致 这 个 新 版 本 无 法 被 

追 跳 继 更， 所 以 建议 不 要 这 诬 做 。 


若 你 要 在 detached HEAD 状态 建立 一 个 可 被 追 中 
的 版 本 ， 那 床 正 确 的 方法 则 是 透明 建立 分 支 , 的 


方式 来 追 跳 ， 现 在 我 们 就 要 在 这 个 版 本 建立 一 个 新 
的 newbranchl 分 支 ， 半 将 工作 目 录 切换 过 去 ， 指 
令 如 下 : 


9it checkout -b newbranchLl 


:NiemoNgit-hbranch-demo>gqit checkout -hb newhbranchi 
Switched to aa new branch :newhbranchil 


:NduemoNgit-hbranch-demo>git branch 
mastek 


newhbranch2 
:NduemoNgit-hbranch-demo>git 1og 


huthor: Will 《doggy.-huangegmail.comy> 
ipate : Fri Oct 4 20:58:16 2013 +08D9 


a-txt: Set 1 as content 


huthor: Will 《doggvy.huangegmail.com> 
IDate : Fri Oct 4 29:094:39 20913 +9889 


Initial commit 


然后 我 们 再 建立 一 个 新 档案 b.txt， 内 容 
为 newbranch1， 站 建立 一 个 新 版 本 ， 指 令 如 下 : 


Sceneognewlomainechn 和 有 之 重 思 两 蕊 区 七 
goesaaa 


geCOmmanie 三 轴 和 和 QOSWloamechhili 


好 了 ， 我 们 现在 有 了 master 以 外 的 两 个 分 支 ， 而 
且 两 个 分 支 都 有 自己 的 版 本 ， 你 先 在 脑 中 思考 一 下 
这 棵 权 长 怎样 ! 


接著 我 们 开 艇 SourceTree 工具 ， 范 将 这 个 工作 目 
杀 加 入 到 SourceTree 的 管理 工具 中 : 


File Edt View Repository Actions TIools Help 


呈 


Clone/New | Commit Checkou Add “Remove Add/Remove 


Adda is ordrag & drop 
repository folders into this area to begin 


Clone /Add/ Create Repository 


下 
辕 qonepepostozl 国 Addworarg copy 下 Create New Repository 
| 


Repository Type 侈 ThisisaGitrepository 
Bookmarks 
[YI Bookmarkthis repository 


Name: Lgit-branch-demo 
Folder | [Root 


加 入 后， 我 们 切换 到 这 个 Git 储存 库 的 分 支 ， 总 共 
有 三 个 ， 我 们 分 别 切 换 过 去 看 看 : 


git-branch-demoe X 


Ce Pt 


Ren 
Date Drder 


4 file Status 


orking Copy ral escription 
的 workingc | Graph Descripi 
4 Branches | Add b.bxtin newbranch1 
| Modify bbd with content 'newbranch2' in ths newb 
罕 newbranch1 AN [时 master] Greate GEWiR ETIEnEWaster ithe TaSEETrSRc 
呈 newbranch2 atxt set 1 as content 
Tags | Initial commit 
Remotes | 
git-branch-demo X 
4 File Status 『 An sranches v 十 vsSFOWRemoteSrnches ss DateOrder ~ 
ing Copy ral escription 
办 Workingc Graph Descripi 


喇 master Modify bbd with content 'newbranch2' in the newb 


4 Branches | Add b.txtin newbranch1 


Create btxt with content 'master in the master branch 
且 newbranch2 atxt set1 as content 
Tags Initial commit 
Remotes 
9it-branch-demo X 
4 File Status 『 Asranches v ShowREmaoteEBranches DateoOrder v 
罗 wWorking copy Graph Description 
4 Branches Add b.txt in newbranch1 
呈 master EEBebenen Modiybbtwithcontent newbranchzinthenenb 
综 newbranch1 Create btbxt with content 'master in the master branch 
atxt set 1 as content 
Tags s Initial commit 
Remotes 


最 早 的 版 本 在 最 下 面 ， 最 新 版 在 最 上 面 ， 当 我 们 切 
换 到 不 同 的 分 支 ， 你 可 看 到 这 三 个 个 分 支 图 示 都 一 
样 ， 只 有 预 设 停 留 的 “ 光 棒 , 不 一 榜 。 首 先 ， 和 从 国 
片 来 看 ， 你 看 到 的 是 整 份 Git 储存 庆 , 中 的 所 有 
版 本 、 所 有 分 支 ， 以 及 该 分 支 是 从 哪个 版 本 开始 建 
立 分 广 的 。 而 “ 光 棒 4 则 是 该 分 支 的 “最 新 版 ， 位 
於 整个 Git 版 本 库 的 哪个 版 本 。 


今日 小 给 


其 实在 Git 壬 面 使 用 分 文 是 很 容易 的 事 ， 准 的 地 方 
在 於 让 大 家 都 知道 分支 : 到 搬 在 做 什么 ， 逮 有 大 
家 对 “〔 分支: 的 想像 是 否 是 一 致 的 ， 只 要 大 家 针 分 
支 的 想像 是 一 致 的 ， 在 转 队 版 控 上 就 不 会 有 大 大 的 
落差 。 


对 我 来 说 ， 分 支 我 会 把 它 想像 成 一 种 ' 快照 , 功 
能 ， 把 叶 个 commit 版 本 和 与 其 历史 版 本 建立 出 一 个 
快照 ， 然 后 复 秽 一 份 出 来 ， 芷 给予 一 个 分 支 名称 ， 
你 可 以 在 这 些 分 支 上 建立 版 本 ， 等 待 日 后 进行 合 
代 。 


而 整 份 Git 储存 库 ， 则 会 保留 所 有 的 分 支 与 版 本 ， 
最 终 呈 现 出 一 个 树 状 架构 的 分 支 图 ， 我 们 最 后 透 过 
SourceTree 工具 可 以 清楚 的 看 到 Git 储存 库 中 的 分 
支 状 况 与 版 本 释 化 。 这 张 图 ， 我 很 早 就 看 过 ， 但 第 
一 次 完全 看 不 懂 ， 只 觉得 是 ' 一 张 图 ， ， 没 有 感 
攻 ， 但 自从 越 来 越 了 解 Git 之 人 后， 这 张 分 支 图 可 以 
让 我 一 目 了 然 的 理解 整个 Git 储存 库 的 变化 情形 ， 
也 更 容易 掌握 Git 的 版 本 释 化 。 


希望 可 以 透 过 我 的 文字 和 与 指令 搭配 图 片 示 和 范 ， 让 大 
家 在 自己 脑 中 勾勒 出 一 个 分 支 惧 构 ， 寺 Git 分 广 续 
构 有 更 帝 屋 的 理解 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git branch 

。git branch [branch_name] 
。git checkout -b [branch_name] 
。git checkout [branch_name] 
。git branch -d [branch_name] 


。git log 
参考 过 结 
。 BRANCHING AND MERGING 
。 HOME 
。 回 目 色 


。 前 一 天 : 解析 Git 资料 结构 - 索引 结构 
下 一 天 : 比 对 档案 与 版 本 差 轴 


第 09 大 : 比 对 榴 案 与 版 本 委 


ww 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/09.md 


使 用 任何 版 本 控 管 软体 的 过 程 中 ， 经 常会 需要 查 
历史 纪 他 与 比 对 版 本 之 问 的 差 星 。 而 在 使 用 Git 的 
时 候 要 如 何人 进行 比 对 ， 将 是 本 文 重点 。 


准 位 工作 目 针 


我 们 透 过 以 下 指令 快速 建立 一 个 扩 有 两 个 档案 与 两 
个 版 本 变更 纪 杀 的 Git 储存 库 与 工作 目 朱 : 


mkadir g9it-dqemo 
cq gd9it-dqemo 
Gaieesinaite 


二 Clnio le 二 ee 
全 包 II 几 o 久 Oo IE>eE 
gsaaae 


Gasecommake mmseasaiaeceemmaaee 


SChe 3 > 电 七 文 七 

臣 区 用人 下 4 和 及 二 

< 协 

GeEECOmimai raise 这 二 二 六 蕊 本 者 台 本 DR ana 4 


关於 git diff 的 基本 观念 


在 Git 中 比 对 两 个 版 本 之 问 的 差 虹 ， 通 常会 
用 sit aiff 命令 , 我们 先 执 行 一 个 简单 的 命令 ， 
比 对 两 个 版 本 之 问 的 差 虹 : 


1. 先 执 行 sgit 1log 取得 版 本 资讯 ， 下 取得 最 近 两 
个 commit 物件 的 id 

2. 我 们 在 执行 git diff commit1 commit2 指 
令 ,， 比 对 两 个 版 本 间 的 差 时 ， 其 中 commit1 请 
用 较 荔 的 版 本 ， 而 commit2 则 用 较 新 的 版 本 。 


如 下 贺 示 : 


:Ngit-dqemo>git 1og 

ommit 8adechhbh4a36?16f?74c643?1h3d23?7?7e58cl126fhb 
huthor: VUilL1 《doggquy-huangegmail.-comy> 
Date : Tue Oct 8 17:38:20 2013 +0800 


Updqate a-txt and b-txt to 3 and 4 
Commit 53ctlffd5215293a2aldqddu49692agBc4942d7943ac: 
huthor: Vi1lL1L 《doggquy-huangegmail.comy> 
Date : Tue Oct 8 17:38:19 2013 +0800 
Initial commit 
:Ng9it-Qdqemo>git diff 53clf 8adec 


IE 一 -gt aa-txt ba-txt 
index 3?hbcc8hb-.- .qd855592 1009644 


IE 一 -git ahb-txt bnhb-txt 
index 8f6bcle5.-8adhb55hb 1069644 


我 们 从 sit aiff 执行 的 翰 出 结果 ， 将 可 得 到 一 个 
执行 的 结果 。 由 於 我 们 这 两 个 版 本 库 中 有 两 个 档 
案 ， 而 且 在 这 两 个 版 本 之 问 也 都 有 典 动 ， 所 以 他 会 
列 出 两 段 " 差 虹 比 对 , 的 结果 。 


各 位 可 以 从 上 图 看 到 每 一 段 都 是 以 aiff --sit 开 
头 ， 代 表 git 对 哪 两 个 横 案 进行 比 对 。 


女人 


第 二 行 的 inaex 37bcc8b..dq855592 100644 则 是 


代表 git 在 做 这 次 比 对 时 的 5 标 头 资讯 J(Header 
Line)， 这 壬 可 能 会 有 好 秋 行 ， 资 讯 不 一 定 只 有 这 
些 。 这 和 里 会 标示 许多 关於 此 次 差 轩 比 对 的 额外 资 
讯 。 例 如 index 这 行 ， 和 后 面 的 两 个 hash id 
(37bccsb. .qd855592) 就 代表 在 Git 物件 储存 库 
(object storage) 中 的 两 个 blob 物件 id， 用 来 比较 这 
两 个 blob 物件 。 在 和 后面 的 100644 则 是 git 属性 ， 
有 点 类 似 Linux 环境 下 的 档案 属性 ， 例 如 宣告 这 是 
个 档案 、 目 录 、 可 读 、 可 写 、 可 执行 之 类 的 。 以 下 
是 几 个 常见 的 git 属性 范例 : 


0100000000000000 (040000) : Directory 
1000000110100100 (100644) : RegulLar non-executab1l 
1000000110110100 (100664) : Regular non-executab1l 
1000000111101101 (100755) : RegulLar executable EL 
00000000000000 帮 如 20000ESymoone ms 
WO000000000000 古 (下 60000 下 本 En En 


相关 束 结 可 参考 以 下 讨论 串 : 


。 How to read the mode field of git-ls-tree's 
output 
。 index-format.txt 


接 下 来 第 三 行 的 --- ay/a.txt 则 代表 两 个 比 对 的 版 
本 中 “比较 睾 的 , 那个 版 本 。 


接 下 来 第 四 行 的 +++ py/a.txt 则 代表 两 个 比 对 的 版 
本 中 “比较 新 的 , 那个 版 本 。 


接 下 来 第 五 行 的 ee -1 +l ee 则 代表 这 个 档案 在 蓝 
版 的 总 行 数 与 新 版 的 总 行 数 ，-1 代表 得 版 只 有 1 
行 ，+1 代表 新 版 也 只 有 1 行 。 


最 后 则 是 列 出 所 有 释 更 的 内 容 ， 这 壬 有 三 种 可 能 的 
表示 法 : 


。 以 减 号 - 号 开头 ， 代 表 和 从 仁 版 到 新 版 的 过 程 
中 ， 此 行 被 删除 了 。 

。 以 加 号 + 号 开头 ， 代 表 和 从 每 版 到 新 版 的 过 程 
中 ， 此 行 是 被 新 增 上 去 的 。 

。 以 空白 字 元 开头 ， 则 代表 这 一 行 在 两 个 版 本 中 
都 有 出 现 ， 没 有 任何 变更 。 


如 此 一 来 就 完成 了 这 两 个 版 本 中 第 一 个 blob 物件 的 
差 虹 比 对 ， 接 著 会 显示 该 版 本 中 第 二 个 blob 物件 的 
差 时 比 对 ， 以 此 类 推 。 


在 Git 中 使 用 sit aiftf 的 时 候 ， 事实 上 是 以 tree 


物件 为 比较 的 单位 ， 我 们 从 【第 06 天 : 解析 Git 资 
料 结 构 - 物件 结构 】 文 章 图 解 与 影片 中 有 学 到 ， 其 
实 每 一 个 commit 物件 都 会 包括 一 个 根 目 儿 的 tree 
物件 。 所 以 我 们 同 映 | 利用 sit aiff 比 对 两 个 
commit 物件 时 ， 其 实 比 对 的 是 commit 物件 下 的 那 
个 tree 物件 ， 而 比 对 的 过 程 又 会 于 迎 的 一 直 比 下 
去 。 由 此 你 应 该 可 以 感受 到 ，Git 的 diff 比 对 机 制 十 
分 强大 ， 你 可 以 很 快速 的 比 对 出 任意 两 个 版 本 之 问 
的 帮 动 比较 。 


在 使 用 sit aiff 命令 时 ， 主 要 有 三 种 tree 物件 的 


来 源 ， 分 别 是 : 


。 在 所 有 的 commit graph 中 存在 的 tree 
object， 也 就 是 任意 版 本 中 任意 一 个 tree 物件 
的 意思 。 

。 索 引 (index)， 代 表 你 已 经 将 档案 状态 送 进 “ 索 
引资 料 库 , 的 那些 资讯 ， 此 时 透 遇 sit aada 命 
令 时 ， 其 实 tree 物件 已 经 被 建立 。 

。 你 目前 的 工作 目 杀 (working directory) ， 验 然 
工作 目 销 的 改 释 还 没有 释 成 tree 物件 ， 但 透 


过 sit aifft 是 可 以 这 样 用 的 。 


四 种 基本 的 比较 方式 


要 透 过 sit aiff 命令 比 对 任意 两 个 版 本 ， 通 常会 


有 以 下 四 种 指令 的 用 法 : 
1. git diff 


在 什么 参数 都 不 加 的 使 用 情况 ， 比 对 的 是 工 
作 目 录 ,， 与 索引 , 之 问 的 差 星 。 这 是 个 很 常 
用 的 指令 ， 因 为 沼 你 执行 sit adad . 指令 之 

前 ， 先 透 过 sit aiff 查看 你 自己 到 底 改 了 哪 
些 东 西 。 


广 : 事实 上 ， 在 使 用 Git 版 本 控 管 的 过 程 中 ， 
在 执行 sit commit 之 前 ， 的 确 有 可 能 会 执 

行 git ada 指令 好 绑 次 ， 用 以 确认 到 底 哪 些 档 
案 要 加 入 到 索引 之 中 ， 最 和 后 才 会 commit 进 版 
本 。 


2.gitdiff commit 


如 果 你 只 在 sit aiff 之 后 加 上 一 个 commit 
id ， 比 对 的 是 上“ 工作 目录 ,与 “指定 commit 
物件 里 的 那个 tree 物件 ，, 。 


有 常用 的 指令 是 sit diff HEAD， 因 为 这 代表 
你 要 拿 " 工作 目录 ,， 与 " 当前 分 支 的 最 新 版 ， 


进行 比 对 。 这 种 比 对 方法 ， 不 会 去 比 对 ' 京 
引 . 的 状态 ， 所 以 各 位 必须 区 分 清楚 ， 你 到 底 
比 对 的 是 甚 友 tree 物件 的 来 源 。 


.git diff --cached commit 


在 执行 sit_ commit 之 前 ， 索 引 状 态 应 该 已 经 
都 准备 好 了 。 所 以 如 果 你 要 比 对 " 当前 的 索引 
状态 ,， 与 “指定 commit 物件 里 的 那个 tree 物 
件 ， ， 就 可 以 用 这 个 指令 完成 比 对 任务 。 


最 弟 用 的 指令 一 柑 

是 sit aift --cached HEAD， 这 个 语法 代表 
的 是 上“ 富 前 的 索引 状态 , 与 " 旬 前 分 支 的 最 新 
版 ， 进行 比 对 。 这 种 比 对 方法 ， 不 会 去 比 对 
工作 目录 ， 的 枚 案 内 容 ， 而 是 直接 去 比 对 

“ 率 引 , 与 "目前 最 新 版 ， 之 问 的 差 旺 ， 这 有 
助 认 你 在 执行 sit commit 之 前 找 出 那些 弧 更 
的 内 容 ， 也 就 是 你 将 会 有 哪些 释 更 被 建立 版 本 
的 意思 。 

广 1: git diff --cached 

与 cit diff --staged 是 完全 一 样 的 结 

果 ) 一 一 Staded 只 是 --Cached 的 列 名 7 让 你 比 


较 好 记 而 已 ! 


广 2: 加 上 d 王 二 =Cacehed 
盟 ait diff --cachedq HEAD 执行 时 也 是 完 
一 样 的 结果 ， 最 后 的 HEAD 可 以 省 略 。 


4. git diff commit1 commit2 


最 后 一 种 则 是 适 过 两 个 不 同 的 版 本 ( commit id 
) 来 比 对 其 差 时 ， 这 个 命令 可 以 跳 过 ' 索引 ， 
与 "工作 目 销 , 的 任何 变更 ， 而 是 直接 比 对 特 
定 两 个 版 本 。 事 实 上 Git 是 比 对 特定 两 个 版 本 
commit 物件 内 的 那个 tree 物件 。 


最 常用 的 指令 则 是 sit aiff HEAD^ HEAD 命 
令 ， 这 代表 你 要 比较 【最 新 版 的 前 一 版 】 和 与 
【最 新 版 】 之 问 的 差 吐 。 这 壬 的 HEAD 与 ^ 的 
意义 ， 我 们 会 在 日 后 的 文章 中 褒 明 。 


今日 小 短 


今天 介绍 的 sit aiff 是 个 很 常用 的 指令 ， 各 位 应 
该 熟练 地 使 用 它 。 我 们 最 和 后 来 复习 一 下 其 常用 指令 
的 差 星 : 


git diff => 工作 目 朱 vs 索引 


加 工 卜 
加 了 上 
加 
加 


Ga 
@aia8oE 
Ga 
Ga R 朋 


HERAD => 工作 目 杀 vs _ HEAD 


--cachedq HEAD => 达 引 vs HEAD 
二 ES => 达 引 VSs HEAD 
HEAD^ HERAD => HEAD^ vs _ HEAD 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


W 


人 参 


E 一 7 


。git log 
git diff 
git diff HEAD 

git diff --cached 

git diff --staged 

git diff HEAD^ HEAD 


考 堪 


士 


坟 人 


。 BASIC SNAPSHOTTING 
git-diff(1) Manual Page 


: 关於 分 支 的 基本 观念 与 使 用 方式 
: 说 识 Git 物件 的 绝对 名 称 


第 10 大 : 认识 Git 物件 的 绚 
对 名 称 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/10.md 


在 Git 版 本 控 管 的 过 程 ， 每 一 个 版 本 就 代表 一 个 
commit 物件 。 又 因为 版 控 过 程 中 经 常会 建立 分 支 ， 
最 终 彦 出 的 commit graph 可 能 会 生 复 杂 的 ， 所 以 
如 何 识 别 不 同 的 版 本 ， 或 是 快速 定位 到 特定 版 本 以 
取得 资讯 ， 就 继 得 很 重要 。 本 篇 文章 将 带 大 家 认识 


Git 里 音 用 的 物件 名 称 概 念 与 使 用 方法 。 


物件 绝对 名 称 


在 Git 中 ， 每 个 物件 都 会 有 一 个 以 SHA1 杂 汉 运算 
过 的 id， 而 这 个 id 就 是 所 谓 的 绝对 名 称 ，。 如 果 
该 物件 是 commit 物件 ， 那 这 就 是 commit 物件 的 绚 
对 名 称 ， 所 以 我 们 只 要 找 出 commit 物件 的 绚 对 名 
称 ， 就 可 以 随时 取得 该 版 本 。 如 下 图 箭头 标示 上 处 ， 
就 是 我 们 透 过 sit 1los 取得 的 commit 物件 id， 我 


们 随时 可 以 取得 仿 commit 物件 的 详细 资 


:Ngit-dqemo>gqit 1o9g 


huthor: WUil1l 《doggvy-huangegmail-comy> 
Wed Oct 9 17:08:17 2013 +0800 


Updqaate a-txt and hbh.txt to 3 and 4 


“: WUill “doggvy-huangegmail- 
Wed Oct 9 17:098:16 2913 


Initial commit 


如 果 我 们 想 看 如 上 图 commit 物件 的 内 容 ， 可 以 利 
用 9it cat-file -Pb commitida 来 取得 7 如 下 转 
示 : 


:Ngit-demo>gqit cat-file -~-D 395a 

kee gz7cl321hbe49815q53ehbh2413foaqd528601B6ehbhb6cc 
liparent 98g9cec2ehbhf32390eec8lieefhbhb623231?31a39824 

uthor Vil1l 《doggvy.huangegmail.-com> 13813909697 +0800 
ommitter Will 《doggv.-huangegmail.com> 13813909697 +0809 


pdate a.txt and hbh.txt to 3 and 4 


物件 绝对 名 称 的 简短 语 ; 


由 於 Git 物件 id 是 透 ee SHA1 杂 小 后 的 结 
果 ， 所 以 很 长 ， 在 Git 标示 上 绝对 名 称 ,， 时 ， 可 以 
用 前 面 作 三 代替 ， 最 少 不 可 低 於 4 个 字 元 。 也 就 是 
说 4~ 40 个 字 元 长 度 的 绝对 名 称 , 都 是 可 以 用 
的 。 


例如 我 们 从 上 图 也 可 以 看 出 在 这 个 commit 物件 的 
的 内 容 包 含 了 一 个 tree 物件 ， 该 物件 也 有 一 个 tree 
物件 的 绝对 名 

称 07c1321be49815dq53eb2413f0ad5286010ebb6cec ， 
所 以 我 也 可 以 再 次 透 过 ait cat-file -p treeid 
来 取得 该 tree 物件 的 内 容 ， 如 下 图 示 : 


:Ngit-demo>git cat-file -D 97cl 
HBB644 blohb qd85559233hbyrcdq24e6139a738f9adqB843795584fdq7 已 -上 tXt 


HL66644 blohb 8adhb55beaa488671fll37tcacce81109fhbdu868d99 hb .txt 


有 时 候 我 们 想 取得 版 本 纪 欠 会 使 用 sit 1log 命令 ， 
同时 也 会 输出 每 个 档案 的 继 更 比较 结果 ， 结 果 会 十 
分 了 见长 ， 这 时 可 以 用 ait 1log --pretty=oneline 
指令 来 取得 较为 ; 机 同时 你 也 可 以 取 
得 commit 物件 完整 的 上“ 绝对 名 称 ，， 如 下 图 示 : 


:Ngit-demo>git 1og --Dketty=oneline 


Updqate a-txt and hb-txt to 3 and 4 
Initial commit 


另外 一 个 音 用 的 技巧 则 是 俊 输 出 部 分 的 “绝对 名 


称 , ， 透 


过 9it 1og --Dretty=one1Line abbrev-commit 


目 令 执 行 即 可 ， 如 下 国 示 : 


:Ng9it-demo>git 1og -Detty=oneline 一 -ahbhbreuw-commit 
Updqate a-txt and hbh-txt to 3 and 4 


Initial commit 


今日 小 短 


以 上 过 就 是 绝对 名 称 的 用 法 ， 由 於 Git 物件 的 特 
性 ， 你 可 以 透 过 物件 的 绝对 名 称 存 取 到 Git 储存 库 
中 任意 物件 ， 还 有 很 多 git 指令 都 会 用 到 绝对 名 
称 ， 熟 悉 了 这 些 概念 与 表示 法 ， 你 将 更 能 掌握 Git 
物件 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git log 
。 git cat-file -p [object_ id] 


gitlog --pretty=oneline 
。git log --pretty=oneline --abbrev-commit 


天 : 比 对 档案 与 版 本 差 暴 
天 : 认识 Git 物件 的 一 般 参 照 与 符号 参照 


第 11 天 : 认识 Git 物件 的 一 


几 2 街 张 参 全 | 
航 参 AAA 电 付 天 多 有 量 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/11.md 


在 说 识 了 Git 物件 的 “绝对 名 称 , 后， 接 下 来 束 要 
介绍 Git 版 控 过 程 中 最 常用 到 的 “参照 名 称 , 。 


认识 物件 的 参照 名 称 


参照 名 称 (ref) 简单 来 褒 就 是 Git 物件 的 一 个 " 指 
标 ， ， 或 是 相对 於 “绝对 名 称 4 的 另 一 个 好 记名 
称 , ， 用 一 个 预先 定 入 或 你 自行 定 贸 的 名 称 来 代表 
某 一 个 Git 物件 。 


在 我 们 之 前 学 到 的 5 分 支 名 称 J 或 我 们 曾经 用 过 的 
HEAD (代表 最 新 版 本 )， 或 是 我 们 之 后 会 学 到 的 


- 标 毓 名 称 ，， 这些 都 是 ' 参照 名 称 , ， 之 就 是 
和 义 了 训 你 好 记 而 已 。 


我 们 以 5 分 支 名 称 J 为 例 ， 来 说 明 一 下 "参照 名 称 ， 


的 实体 结构 为 何 。 以 下 图 为 例 ， 我 们 透 

过 sit branch 取得 所 有 分 支 名 称 ， 你 可 以 看 至 我 

个 分 支 ， 然 而 这 三 个 分 支 的 名 称 其 实 

一 个 5 参照 名 称 1， 这 代表 这 三 个 5 参照 名 称 ， 

刚 则 应 到 Git 物件 储存 库 中 的 三 个 commit 物件 。 

在 下 图 中 你 也 可 以 看 出 这 些 分 支 的 参照 名 称 其 实 就 
是 一 个 档案 而 已 ,所 有 上 本 地 分 支 , 的 参照 名 称 皆 

位 於 .ait\refs\heads 目 尔 下 : 


:NduemoNgit-hbranch-demo>gqit branch 
masStek 


newhbranch2 
"vanch-dqemo>dqir -9qitNefs\heads 
磁 开 是 System 
361C-6BD6 
C:vdemoNgit-branch-dqemo\-gitvrefs\heads 的 目 铬 
遇 逢 19:16 <《DIRy> 
41 master 
41 newpbranchil 


PB9137L9D4 间 - 41 newhbranch2 
123 位 元 


铬 19.668.625.929 位 


接著 我 再 以 下 图 来 证 明 这 个 档案 是 如 何 跟 ' 绝对 名 
称 , 做 连结 。 我 先 透 过 sit branch 取得 所 有 分 支 
名 称 ， 郊 发 现 目前 "工作 目 人 , 是 指 
向 newbranchl 这 个 分 文 。 此 时 我 们 透 
过 aoit 1og --pretty=oneline 即 可 取得 该 分 支 的 


所 有 版 本 纪 从 。 预 设 这 些 分 支 的 “参照 名 称 , 会 指 


向 分 支 的 “最 新 版 ， 我 们 只 要 打 

开 .ait\refts\headqs\newbranchl 档案 的 内 容 ， 就 
可 以 看 出 这 是 一 个 纯 文 字 档 而 已 ， 而 且 是 指向 版 本 
历史 纪 杀 中 的 “最 新 版 ，。 本 

以 ait cat-file -p 0bd0 取得 该 commit 物件 的 
内 容 ， 以 及 用 ait show 0bd0 取得 支 版 本 的 变更 纪 
外 ， 藉 此 证 明 这 些 档案 就 是 "参照 名 称 , 的 主要 用 


:NduemoNgit-hbranch-demo >git branch 
mastem 
newhbhranchi 


newhbranch2 


:NduemoNgit-hbranch-demo>git 1og 一 -Detty=oneline 
5161: CO hddq b-txt in newhbranchi 
已- 起 Xt: Set 1 as content 
Initial commit 


:NduemoNgit-hbranch-demo >type -9qitNrefs\heads\newhbranchi 
四 bdup3463627914979645c5fad46f965161cB3ac6 


:NduemoNgit-hbranch-demo>git cat-file -D 09hbdqg 

Fee 19f9596731hbl94109a9agdqf3b427c8698hbB74666ff5 
jparent hbh9?917758cof2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Will 《doggv-huangegmail.-com> 13809896179 +D800 
ommitter WUill 《doggv-.huangegmail.com> 1380896179 +0800 


dd b-txt in newhbranchi 


:NdemoNgit-hbranch-demo>git show 0hbdqg 
commit 9hbdg346362?7914979645c5fad469f99516lci 


上 uthor: Wil1l 《doggy-huangegmail.-com> 
Date : Fri Oct 4 22:16:19 2013 +08090 


hddq hb-txt in newhbranchi 


Ef 一 -9it ahb-txt bnhb-txt 
ew file mode 1096644 

index _ 09698668. -669cdq61 

-- vdeuvnu1l1 

+++ bb .txt 


我 们 再 透 过 指令 看 看 使 用 ' 绝对 名 称 , 与 " 参照 名 
称 , 读 取 特 定 commit 物件 的 内 容 ， 证 明 这 两 个 指 
令 执 行 的 结果 是 相同 的 : 


:NduemoNgit-hbranch-demo >type -9qit\refs\heads\newhbranchi 
Dhbqu6346362?7914978645c5fad46f665161cgB3ac6 


:NduemoNgit-hbranch-dqemo>git cat-file -pD newhbranchi 

Fee 19f996731blo41oa9apdf3hbh427c898hbg740966ff5 
jparent b9?917?758cg9f2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Will 《doggvy.huangegmail.-com> 1380896179 +0800 
ommitter Will 《doggvy-huangegmail.-com> 13809896179 +0800 


dd hb-txt in newhbranchil 


:NduemoNgit-hbranch-demo>gqit cat-file -D 9hbdqg 

Fee 19f996731blo41oa9apdf3hbh427c898hbg740966ff5 
jparent b9?91?7?58cgf2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Will 《doggy-.huangegmail.com> 13809896179 +09869 
ommitter Will 《doggqvy-.huangegmail.-com> 13809896179 +0800 


dd hb-txt in newhbranchil 


在 大 多 数 的 情况 下 ， "参照 名 称 , 通常 都 会 指向 一 
个 commit 物件 ， 但 东非 必要 ， 你 也 可 以 指向 其 他 
Git 物件 类 型 ， 像 是 blob 物件 、tree 物件 、tag 物 


件 等 等 。 


关於 .gityrefs/ 目 销 


从 上 述 和 范例 其 实 已 经 能 看 出 ， 所 有 的 “参照 名 称 ， 
,而且 一 律 放 在 sit/refs/ 目录 下 。 而 
Git 的 参照 名 称 所 放置 的 目录 位 置 ， 主 要 有 三 个 : 


。 本 地 分 支 : .9it/refs/headqs/ 


。 款 端 4 分 支 .gjit/refs/remotes/ 


村 鲜 : .djit/refs/Ladgs/ 


EN 如 果 你 建立 一 个 分 支 名 称 


为 f2e， 这 时 你 会 知道 本 地 分 支 的 了 参照 名 称 ， 


建立 .glit/refs/nheadqs/f2e 档案 如 下 贺 示 


:NduemoNgit-hbranch-demo>git branch 
mastek 


newhbranch2 


Ndemo Ngit-hbr h-dquemo >dqir -qitNeefs\heads 
举 区 C 中 乓 碟 是 System 
举 区 序 跨 : ”361C-6BD6 


C:NduemoNgit-hbranch-dqdemo\-.gitNefs\heads 时 上 自 舒 


PB13A1LBxXLD :32 《DIRy> 相 
PB137A1LBx1LB :32 《DIR> 成 
Po913L9-94 间 :12 41 master 
PB13A1LB7B4 避 :16 41 newhbranchil 
PPB1371BAB4 间 :23 


:NduemoNgit-hbranch-demo>gqit branch f2e 


NdquemoNgit-hbranch-demo>dir -9qitNrefs\heads 
站 匣 C 中 
党 尼 序 不: 


C:NduemoNgit-branch-demo\-gitNefs\heads 


Po13v1iez1ie 上 和 92:34 《<DIR> 

Paeli3zvtiez1ie 上 和 82:34 <DIR> 本 

Pal13zx1ev1e 上 和 于 62:34 于 2e 

Pali3zv1Bve4 下 午 89:12 

Pei3v19ve4 下 午 19:16 newhbranchi 

Pal3《1Bve4 下 午 899:23 newphbranch2 
人 


田 
个 目 匀 ”19-271.846 .409 


事实 上 ， 这 个 f2e 的 上 全 名 , 应该 叫 


做 refs/heads/f2e 才 对 ， 只 是 Git 允许 你 输入 简 


写 ， 方 便 你 快速 输入 参照 名 称 而 已 。 如 下 图 示 
三 种 使 用 ' 参照 名 称 , 的 方式 都 是 可 行 的 


:NduemoNgit-hbranch-demo>git cat-file -D 09hbdg 

kee 19f996731hbl6416a9a0df3hbh427c8098hbB745966ff5 

akent hbh9?917758cgf2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Will 《doggvy-huangegmail.com> 13809896179 +08090 
ommitter Will 《doggvy.-huangegmail.com> 13809896179 +0800 


dd hb.txt in newhbranchl 


:NdemoNgit-hbranch-dqemo>git cat-file -pD kefsheads/f2e 
kee 19f966731hblB4l1oa9aBdqf3hbh427c8698hba746966ff5 

akent hb9?17758cof2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Will 《doggvy-huangegmail.com> 1380896179 +0800 
ommitter Will 《doggqvy-huangegmail.com> 1380896179 +0800 


dd hb.txt in newhbranchil 


:NduemoNgit-hbranch-demo>git cat-file -D heads/f2e 

hee 19f996731hbl6410a9agdf3hbh427c898hbaz740966ff5 

akent hb9?17758cof2f347a895ee5hbhbhb5ce5c8228f66335a 

uthor Will <doggvy.-huangegmail.com> 1380896179 +0809 
ommitterkr Will 《doggqvy.huangegmail.com> 13809896179 +09809 


dd hb.txt in newhbranchi 


: vdemo Ngit-hbranch-dqemo>git cat-file -pD f2e 

kee 19f906731hbl9410a9a0dqf3hbh427c898hbB746966ff5 

akent hb9?17758cof2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Vill 《doggvy.huangegmail.-com> 13809896179 +0800 
ommitter WUill 《doggvy-huangegmail.com> 138090896179 +0800 


dd hb.-txt in newhbranchl 


不 过 当 你 输入 参照 名 称 的 简称 ,时 ， 预 设 Git 会 
依照 ai i 只 要 找到 则 订 
的 档案 ， 就 会 立刻 回 传 该 档案 内 容 的 “物件 绝对 名 


。 .git/< 参 照 简称 > 
。 .g9it/refs/< 


。 .git/refs/tags/< 参 照 简 称 ; 标 毓 名 称 > 


。 .git/refs/heaqs/< 参 照 简称 ; 本 地 分 支 名 称 > 
。 .git/refs/remotes/< 参 照 简称 > 


As 二 和 


。 .9it/refs/remotes/< 参 照 简称 ; 下 端 分 支 名 称 >/HEAD 


例如 ， 沼 你 输入 sit cat-file -P f2e 指令 的 话 ， 
那 么 Git 就 会 用 以 下 顺序 找到 相对 的 “参照 名 称 
档 ，， 取 出 该 档案 的 内 容 ( 即 Git 物件 的 纪 对 名 

称 ) : 


。 .git/f2e --> 找 不 到 此 档案 

。 .git/refs/f2e --> 找 不 到 此 档案 

。 .git/refs/tags/f2e --> 找 不 到 此 档案 

。 .git/refs/heads/f2e --> 找到 了 参照 名 称 ， 
以 下 就 不 继续 搜寻 


。 .dgit/refs/remotes/f2e 


。 .qit/refs/remotes/f2e/HEAD 


岂 


认识 物件 的 符号 参照 名 称 (Symref) 


符号 参照 名 称 (symref) 其 实 也 是 参照 名 称 (ref) 的 
一 种 ， 只 是 内 容 不 同 而 已 。 我 们 从 下 图 应 可 看 出 其 
内 容 的 差 时 ， ' 符号 参照 , 会 指向 另 一 个 "参照 名 
称 ，， 半 且 内 容 以 ref: 开头 : 


:NduemoNgit-hbranch-demo >type -9it\HEhD 
ef : befsAheadsnewhbranchi 


:NduemoNgit-hbranch-demo>type -qit\refs\heads\newhbranchil 
DBbaa3463627?79149768645c5fad46fB65161cB3ac6 


:NduemoNgit-hbranch-demo>gqit cat-file -~-D 9hbdqg 


kee 19f996731blo4109a9apdf3hbh427c898hbg974966ff5 
iparent b9?917758cgf2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Vill 《doggvy-.huangegmail.-com> 1380896179 +0800 
ommitter Will 《doggqvy-.huangegmail.com> 13809896179 +0809 


dd hb-txt in newhbranchi 


在 Git 工具 中 ， 预 设 会 维护 一 些 特别 的 符号 参照 ， 
方便 我 们 快速 取得 常用 的 commit 物件 ， 且 这 些 物 
件 预 设 都 会 储存 在 .sit/ 目 朱 下 。 这 些 符号 参考 有 
以 下 四 个 : 


。 目 EAD 


〇 了 永 让 会 指向 "工作 目录 , 中 所 设 定 的 【分 
当中 的 “最 新 版 ，。 
C 所 以 营 你 在 过 个 > 支 执 行 sit commit 
人 后， 这 个 HEap 符号 参照 也 会 更 新 成 该 分 
支 最 新 版 的 那个 commit 物件 。 
。 ORIG_HEAD 


〇 简单 来 说 就 是 HEAD 和 这 个 commit 物件 的 
"前 一 版 ，， 和 经 常用 来 复原 上 一 次 的 版 本 
变更 。 
。 FETCH _ HEAD 


〇 使 用 踪 端 储存 库 时 ， 可 能 会 使 
用 sit fetch 指令 取 回 所 有 这 端 储存 库 
的 物件 。 这 个 FETCH_HEAD 符号 参考 则 
会 记 凶 和 踪 端 储存 库 中 每 个 分 支 的 HEAD 
(最 新 版 ) 的 “绝对 名 称 ,， 。 
*。 MERGE_HEAD 


O 沼 你 执行 合 们 工作 时 (关於 合 供 的 议题 会 
在 日 后 的 文章 中 会 提 到 ) ，“" 合 供 来 源 J 的 
commit 物件 绝对 名 称 会 被 记 针 在 
MERGE_HEAD 这 个 符号 参照 中 。 


一 般 参 照 与 竺 号 参照 的 使 用 方式 


我 们 知道 “参照 名 称 ， 有 特殊 的 目的 ， 通 常用 於 
本 地 分 支 ! 、“ 下 端 分 支 ， 与 ' 标 敏 ,等 情境 
下 ， 但 事实 上 你 可 以 建立 任意 数量 的 “ 自 订 人 参照 名 
称 ，， 只 要 透 过 sit update-ref 就 可 以 自由 建立 


7 一 般 参照 ， 


A O 


N 


我 企图 建立 一 个 名 为 Initialcommit 的 一 般 参 照 ， 
下 指向 Git 储存 库 中 的 第 一 个 版 本 ， 请 参见 如 下 图 
的 指令 执行 顺序 ， 得 知 一 般 参 照 的 建立 方式 : 


NduemoNgit 一 人 站 


:NduemoNgit-hbranch-demo>gqit 1o9 
96 


)mm1 9hbdug346362791 


4 


c5fad49fDB 


uthor: Will 《doggy.huangegmail.-com> 
和 Date : Fri Oct 4 22:16:19 2013 +0800 


hdd hb.txt in newhbranchi 


有 


hbhbjl 


站 uthor : will 《aa ng comy> 
Date : Fri Oct 4 20:58:16 2013 +09860 


己 -txt: Set 1 as content 


Jed4fe2eegb5hbhg0d4pb 


4bifi 


有 uthor: Will 《doggvy-huangegmail-com> 
和 Date : Fri Oct 4 20:094:39 2013 +0800 


Initial commit 


-9it\InitialCcommit 


:NduemoNgit-hbranch-demo>gqit cat-file -D aa3e 
kee ?79hbh419elc6hble52dle4e7432hbh4qhb48098faf?6cc4 
uthor Will 《<doggvy-huangegmail.com> 1380888279 +0809 
ommitterkr WUill 《doggvy-huangegmail.com> 1380888279 +0800 


Initial commit 


:NduemoNgit-hbranch-demo>gqit update-ef InitialCommit aa3e 


:NduemoNgit-hbranch-demo >type 
a3e4fe2eeg65hbhp46egoa74hbhlif12a0hbof8154003 


1 
1 绚 
Git We 


下 计 仅 
日 又 


-9git\InitialCcommit 


昌 召 
后 


VAVA 


.9it 但 


名 称 ) 


资料 丈 下 ， 且 
都 能 存 取 特 定 


:NduemoNgit-hbranch-demo>git cat-file -D aa3e 

kee ?79hbh419elc6hble52dle4e7432hbh4dqhb4898faf?6cc4 

uthor Will 《doggvy-.huangegmail.com> 1380888279 +0800 
ommitter WUill 《doggqvy-huangegmail.-com> 13809888279 +0800 


Initial commit 


:NduemoNgit-hbranch-demo>git cat-file -~-D InitialCcommit 
kee ?79hbh419elc6ble52dle4e7432hbh4dqb4898faf ?6cc4 

uthor Will 《doggvy.huangegmail.com> 1380888279 +08600 
ommitter Will 《doggy.huangegmail.com> 13809888279 +0809 


广 : : 请 记得 ， 参 照 名 称 可 以 指向 任意 Git 物件 ， 半 
没有 限定 非 要 commit 物件 不 可 


ns 最 好 加 上 refs/ 开 
头 ， 例 


亲 '. 9it_ update-ref refs/InitialCommit [object_idq]o。 


出 


若 要 删除 一 般 参 照 ， 则 可 以 使 用 -a 选项 。 如 下 图 


:NduemoNgit-hbranch-demo>git update 一 ef 
: 9git update-Fef [options] -dd 《kefname> [oldqdval>] 
: 9it update-Fkef [options] 《Fefname>《newual> [olduvual>] 


-m 《keasony> Feason of the update 
-Q delete the efekence 
一 -no 一 Qekef Update 《efname> not the one it points to 


:NduemoNgit-hbranch-demo>git update-Fef -qd InitialCcommit 


:NdemoNgit-hbranch-demo>git cat-file -~-pD InitialCommit 
EEatal: Not a ualid ohbject name InitialCcommit 


是 示 所 有 参照 的 方式 ， 则 可 以 使 用 sit show-ref 
指令 ， 如 下 图 示 


:NdemoNgit-hbranch-dqemo>gqit Show 一 ef 
baq6346362?7914678645c5faqd46fD65161cB3ac6 kefs-headsA/ 2e 
E2afc6pb3e5ee2a8chbho48399ag06eg8419e348flee befs-heads/mastekr 
昌 bdaug34636279140976645c5fad46fBD95161cg3ac6 kefs/ headsnewhbranchl 
DB4cfBdu9afbofabobe6185a788?77ad9397632dq3b6 kefs-heads-newhbranch2 


:NduemoNgit-hbranch-demo>gqit update-Fef kefs-Initialcommit aa3e 


:NdemoNgit-hbranch-dqemo>git Show 一 ef 
a3e4fe2eeg965hbh946egga74hb1f12aghbof8154993 Fefs/ InitialCcommit 
hbaua346362?7914078645c5fad46fD995161cg3ac6 kefs-heads/ 2e 
E2afcb6hbh3e5ee2a8chbB48399ag6eg8419e348flee Fefs-heads/mastekr 
bdqu934636279149768645c5fad49f695161cg93ac6b6 kefs/ headsnewhbranchil 
4cfodu9afhbofahboabe6185a78877adg9397632d3b6b kefs-heads-newhbranch2 


若 要 建立 与 删除 " 符号 参照 ， 可 以 参考 如 下 

git symbolic-ref 的 用 法 。 请 自行 看 图 褒 故 
事 ， 理 解 之 后 ， 你 真 的 会 发 现 Git 对 於 参照 的 用 法 
非常 轰 活 且 强 大 。 逮 有 ， 执 行 5it show-ref 只 会 
颗 示 在 .sit\refs 目 销 下 的 那些 参照 ， 而 且 不 管 是 
[一般 参照 ,或 “符号 参照 ， 都 一 样 : 


:NduemoNgit-hbranch-demo>git branch 
上 2e 


ne 


newhbranch2 


:NduemoNgit-hbranch-demo>git cat-file -D f2e 

kee 19f996731bl9419a9apdqf3b427c808bg974966ff5 
lparent b917758cBf2f347a895ee5hbhbhb5e5c8228f66335a 
Will 《doggvy-huangegmail-com> 13809896179 +0800 
Will “doggvy.huangegmail.com> 1380896179 +D800 


utho 
DOmmittekr 


ad b-txt in newhbranchi 

:NdemoNgit-hbranch-demo>git cat-file -D kefs/headsA/ 2e 

kee 19f996731bl9419a9apdqf3hb427c898hbB74966ff5 
lparent b917?7?758cBf2f347a895ee5hbhbhb5e5c8228f66335a 

uthor Will《doggqy.-huangegmail.com> 1380896179 +0800 

ommitter WUill 《doggqvy-huangegmail.-com> 1380896179 +0800 

hadq hb.txt in newhbranchil 

:NduemoNgit-hbranch-demo>git Symbolic-Pef f2e_init Fefs/heads/f2e 


:xiemoNgqit-hbranch-demo>type -qit\f2e_init 


ef : Pefs-headqdsA2e 
:NemoNgit-hbranch-demo>git Symbolic-ref Fefs/f2e_init2 kefs/headsA/ 2e 


:NdemoNgit-hbranch-demo>type -9qitNrefs\f2e_init2 


ef : Fefs-headqdsA 2e 


:NdemoNgit-hbranch-qemo>git Show 一 ef 


bdqa34636279149769645c5fad49f995161cgB3acb6 
baq8346362?79149789645c5fad49f995161cB3acb6 
E2afc6hb3e5ee2a8chbB48399ag6eg8419e348f1ee 
baq6346362791497?79645c5fad409f995161cB3acb6 


Fefs/f2e_init2 
Fefs/heads/ 人 2e 
Fefs/heads/mastekr 
kefs/heads/newhbranchi 


4cfBdq9afhb6fabghbe6185a78877ad9397?7632dq3b6 Fefs/heads-newhbranch2 


电 召 到 
器 


Am\ 土 


本 文 稍 早 提 到 你 可 以 建立 参照 到 以 下 目 凶 : 


。 .dgit/< 参 照 简称 > 

。 .git/refs/< 参 照 简称 > 

。 .git/refs/tags/< 参 照 简 称 ; 标 答 名 称 > 

。 .git/refs/headqs/< 参 | 限 简称 ， 本 地 分 支 名 称 > 

。 .9git/refs/remotes/< 人 参照 简 称 

。 .git/refs/remotes/< 参 照 简称 ; 下 端 分 支 名 称 >/HEAD 
自 订 参照 通常 会 自行 建立 在 前 两 个 路 径 下 ， 以 免 分 


不 清 跟 我 们 使 用 " 本 地 分 文 : 、 


- 标 毓 ,的 使 用 方式 。 不 过 ， 你 的 确 可 以 利 


用 9it update-ef 建立 任何 自 订 参照 7 知 把 自 订 
参照 建立 在 *efs/headsy/will 的 话 ， 也 等 同 於 建立 


本 人 罩 名 和 will 的 分 支 ， 而 Git 真 的 就 是 这 诬 单 
纯 ， 当 你 越 来 越 了 解 Git 的 内 部 结构 ， 也 会 更 加 喜 
欢 上 Git 的 各 种 特性 。 


今 今日 小 颖 


我 们 知道 “参照 名 称 (ref) ， 简单 来 说 就 是 Git 物件 
的 一 个 “" 指标, ， 用 来 指向 特定 Git 物件 ， 所 以 你 
可 以 把 "参照 名 称 , 想像 成 Git 物件 绝对 名 称 的 别 
名 (Alias)， 用 来 帮助 记 剧 。 在 Git 和 里， 有 许多 机 人 制 
昌 人 丽人 辐 全 , 例如 "分支 、“ 标 毓 ， 等 


等 ， 这 些 机 制 骨子里 其 实 就 是 靠 参照, 完成 的 。 
Git 参照 名 称 又 有 区 分 "一般 参 照 , 与 ' 符号 参 
照 : ， 两 者 的 用 途 一 模 一 样 ， 只 在 於 内 容 不 六 一 
样 。 ' 符号 参照 ， 会 指向 另 一 个 ' 一 般 参 照 , ， 而 


-一般 参照 ， 则 是 指向 一 个 Git 物件 的 “绝对 名 
称 , 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git branch 


gitlog --pretty=oneline 
gitlog --oneline 

git cat-file -p [ref or object_ id] 
git show [ref or object_ id] 

git update-ref 

git symbolic-ref 

git show-ref 


前 一 天 : 认识 Git 物件 的 绝对 名 称 
下 一 天 : 认识 Git 物件 的 相 半 名 称 


第 12 大 : 认识 Git 物件 的 相 
对 名 称 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/12.md 


在 认识 了 Git 物件 的 “绝对 名 称 , 与 参照 名 称 ， 
人 后， 最 和 后 我 们 来 介绍 Git 版 控 过 程 中 也 很 常用 到 的 
相对 名 称 , 。 


我 们 再 复习 一 次 ， 在 Git 版 本 控 管 的 过 程 ， 每 一 个 
版 本 就 代表 一 个 commit 物件 ， 每 个 commit 物件 会 
有 一 个 ' 绝对 名 称 ，， 该 名 称 是 将 内 容 以 SHA1 杂 
小 运算 和 后 的 一 个 40 字 元 的 字 串 ， 你 可 以 用 前 4 ~ 
40 个 字 元 来 当成 该 commit 物件 的 识别 名 称 。 版 控 
的 过 程 中 ， 也 可 以 让 你 透 遇 ' 参照 名 称 , 来 代表 有 某 
个 commit 物件 ， 每 个 "参照 名 称 , 最 终 会 对 麻 到 
一 个 物件 的 ' 绝对 名 称 , 。 而 “参照 名 称 ， 又 区 分 
-一般 参 照 , 与 ' 符号 参照 ， 其 中 "一般 参 照 ， 
直接 对 应 到 5 绝对 名 称 1， 而 “符号 参 照 , 则 是 对 应 


到 另 一 个 “一 般 参 照 ，。 


这 篇 文章 所 要 介绍 的 则 是 透 过 “相对 名 称 , 的 表示 
法 ， 让 你 找到 特定 commit 物件 和 后 ， 用 相 针 的 位 置 
来 找到 其 他 的 commit 物件 ， 。 


相 半 名 称 的 表示 法 


使 用 相对 名 称 其 实 非 常 简单 ， 这 壬 有 两 个 特殊 符号 
你 必须 记得 ， 一 个 是 “ ~ 符号 。 


如 果 要 找到 了 Eap 的 前 一 版 本 ， 我 们 会 使 用 azap~ 
或 HEap~l 来 表示 HEAD 这 个 commit 物件 的 前 
一 版 , 。 广 : 这 壬 你 雁 该 已 经 很 清楚 aap 是 一 个 
Git 内 建 的 上 符号 参照 名 称 ，， 代 表 目 前 分 支 的 最 新 
版 。 


如 果 你 要 找 出 另 一 个 f2e 分 支 的 前 两 个 版 本 (不 
含 f2e 的 HEap 版 本 ) ,你 则 可 以 用 f2e~2 或 
用 f2e~~ 来 表示 ， 这 就 是 最 基本 的 表示 方法 。 


在 没有 分 支 与 合 供 的 储存 库 中 ， 关 於 ^1 与 ~:1 所 
表 巡 的 意思 是 完全 相同 的 ， 都 代表 前 一 版 ， 。 但 
本 全 ， 》 支 与 合 供 的 储存 库 中 ， 他 们 有 不 同 的 


关於 commit 物件 役 此 问 的 过 续 


比较 常见 的 Git 储存 库 ， 预 设 只 会 有 一 个 “ 根 
commit 物件 ， ， 也 就 是 我 们 最 一 开始 建立 的 那个 版 
本 ， 又 称 上 初始 送 交 ,人 (Initial Commity)。 你 也 至 少 
要 有 第 一 个 commit 物件 后 才能 开始 分 支 ， 所 以 我 
们 可 以 说 : “在 一 个 Git 储存 库 中 ， 所 有 的 commit 
物件 中 ， 除 了 第 一 个 commit 物件 外 ， 任 何其 他 的 
commit 物件 一 定 都 会 有 一 个 以 上 的 上 属 commit 物 
件 (parent commit) : 。 为 什么 有 可 能 有 ' 一 个 以 
上 1, 的 上 属 commit 物件 呢 ? 因为 你 很 有 可 能 会 合 
儒 两 个 以 上 的 分 支 到 另 一 个 分 支 壬 ， 所 以 合 供 完 成 
后 的 那个 commit 物件 就 会 有 多 个 parent commit 
物件 。 


我 们 用 个 简单 的 例子 来 证 明 这 点 ， 我 们 

用 ait cat-file -p [object_idq] 来 取得 最 前 面 
两 笔 commit 物件 的 内 容 ， 和 精 此 了 解 到 每 个 commiit 
物件 确实 一 定 会 有 parent 属性 ， 芷 指向 上 属 
commit 物件 的 绝对 名 称 ， 唯 独 第 一 笔 commit 物件 
不 会 有 parent 属性 。 如 下 图 示 : 


:NemoNgit-hbranch 一 3 1og 
)mmal 09hbdug34636279 ofadd48fBDL 
上 uthor : Wil1L 《doggv - es Comy> 
Fri Oct 4 22:16:19 2013 +9869 


hddq hb-txt in newhbranchil 


hj 《 
icom> 
+D800 


F12aDhbDpf81i540I 
-COom> 
+D0800 


上 牛 11 《doggvy.-huangegmail-c 
" Will 《<doggvy.huangegmail.Som> 1380888279 +0800 


ommit 


it-hbranch-dqdemo>git cat-file -D b917 
ef4295738a5g015fc4?7d9cfe634dy7d5eae466 
iparent aa3e4fe2eeg65bg46egga74hbhlif12aghbofs8l154063 
uthor Will 《doggvy-huangegmail.com> 1380891496 +0800 
ommitter Will 《doggqvy-.huangegmail.com> 13809891496 +0809 


.txt: Set 1 as content 


了 解 相 峙 名称 表示 法 “与 - 的 差 加 


关於 ~ 的 意 贸 ， 代 表 ' 第 一 个 上 屋 commit 物件 ， 
的 意思 。 


关於 “ 代表 的 意思 则 是 “ 扒 有 多 个 上 属 commit 物 
件 时 ， 要 代表 第 几 个 第 一 代 的 上 屋 物 件 , 。 


如 果 你 有 一 个 “参照 名 称 , 和 为 c， 各 要 找到 它 的 第 
一 个 上 屋 commit 物件 ， 你 可 以 有 以 下 表妹 方式 : 


和 疙 下 


如 果 你 要 找到 它 的 第 二 个 上 属 commit 物件 (在 没有 
合 供 的 状况 下 )， 你 可 以 有 以 下 表 过 方式 : 


0 


但 你 不 能 用 c^2 来 表达 “ 第 二 个 上 屋 commit 物 
件 ，! 原因 是 在 没有 合 供 的 情况 下 ， 这 个 c 只 有 一 
个 上 屋 物件 而 已 ， 你 只 能 用 c^2 代表 ! 上 一 屋 物件 
的 第 二 个 上 履 物 件 , 。 


上 述 讲 起 来 有 点 抽象 又 有 点 缆 口 ， 我 特别 书 了 一 张 
图 给 各 位 看 一 下 ， 透 过 图 解 可 能 会 比较 明白 些 。 如 
下 图 示 ， 我 们 想 找到 c 这 个 commit 物件 的 相对 路 
径 下 的 其 他 commit 物件 (上 层 物 件 )， 由於 c 这 个 
commit 物件 有 三 个 上 层 物 件 ， 这 代表 这 个 commit 
物件 是 透 过 合 儒 而 被 建立 的 ， 那 么 你 要 透 过 相对 
名 称 , 找到 每 一 个 路 径 ， 就 必须 搭配 组 合 ^ 和 与 ~ 


的 使 用 技巧 ， 才 能 定位 到 每 个 你 想 开启 的 版 本 。 


Cn1 或 Cx 或 C~1 Cn2 Cn3 
Cn1~1 或 Co-1 或 C~2 Cn2~1 Cn3-~1 
CA1~2 或 Ci~-2 或 C~3 Cha2~2 Cna3~2 
Cn1~3 或 CA~3 或 Cr~4 CnA2~3 Cn3~3 
个 M 妃 . 指令 
外 绍 9it rev-Parse J 日 之 


在 Git for Windows 工具 壬 有 个 sit rev-parse 指 
令 ， 透 过 这 个 指令 可 以 把 任意 "参考 名 称 , 或 上“ 相 
对 名 称 , 解析 出 “绝对 名 称 ，， 内 然 这 工具 不 是 很 
常会 用 到 ， 但 做 Git 教学 的 时 候 逮 给 实 用 的 。 用 法 
如 下 范例 : 


。git rev-parse master 

。git rev-parse HEAD 

。git rev-parse ORIG_HEAD 
。git rev-parse HEAD^ 

。git rev-parse HEAD~5 


今日 小 短 


当 瞳 解 了 “相对 名 称 4 后， 在 Git 中 表示 commit 
物件 的 各 种 方式 已 经 讲解 完 时 ,相信 你 应 该 更 能 掌 
握 Git 各 版 本 之 问 的 操作 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 
。git log 


。 git cat-file -p [object id] 
。git rev-parse 


: 认识 Git 物件 的 一 般 参照 与 符号 参照 
: 暂 存 工作 目 杀 和 与 雪 引 的 释 更 状态 


第 13 大 : 草 存 工作 目录 与 系 
5 的 释 更 状 感 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/13.md 


有 没有 遇 过 这 种 情境 ， 寻 个 系统 开发 写 到 一 半 ， 结 

果 被 老 半 或 客户 ' 插 单 ，， 被 要 求 紧急 修正 一 个 现 

有 系统 的 Bug 或 添加 一 个 功能 ， 眼 前 的 程式 即将 完 
成 ， 老 加 的“ 急 件 ， 又 不 能 拖 ， 一 个 未 完成 的 软体 

开发 状态 外 加 紧急 调整 的 需求 ， 这 简直 是 软体 品 蚁 

的 一 大 考验 。 如 果 你 有 这 种 困 摄 ， 那 床 Git 可 以 漂 

亮 的 划 你 完成 任务 。 


认识 git stash 指令 


我 们 知道 使 用 Git 版 控 的 时 候 ， 有 区 分 " 工作 目 
朱 , 与 "索引 。 工 作 目 杀 守 面 会 有 你 改 到 一 半 膛 
没 改 完 的 档案 (尚未 加 入 索引 )， 也 有 新 增 档案 但 膛 
没 加 入 的 横 案 (尚未 加 入 么 3 引 )。 而 放 在 勾引 的 资 
料 ， 则 是 你 打算 透 过 sit commit 建立 版 本 (建立 


commit 物件 ) 的 内 容 。 


当 你 功能 开发 到 一 半 ， 被 紧急 插 单 一 定 手忙脚乱 ， 
尤其 是 手 和 正 改写 到 一 半 的 那些 程式 码 不 知 该 如 何 
是 好 。 在 Git 壬 有 个 sit stash 指令 ， 可 以 自动 攻 
你 把 改写 到 一 半 的 那些 横 案 建立 一 个 “特殊 的 版 
本 4 (也 是 一 个 commit 物件 )， 我 们 称 这 些 版 本 篇 
stash 版 本 ， 或 你 可 以 直接 称 他 筷 " 暂 存 人 版 ， 。 


暂 仓 人 版 本 
我 们 手记 改 到 一 半 的 档案 ， 可 能 会 有 以 下 状态 : 


。 新 增 档案 (尚未 列 入 追 跳 的 档案 ) (untracked 
flles) 

。 新 增 档案 (已 经 加 入 索引 的 档案 ) (trackedy/ 
staged files) 

。 修改 档案 (尚未 加 入 么 引 的 档案 ) (tracked/ 
Unstaged flles) 

。 修改 档案 (已 经 加 入 寺 引 的 档案 ) (trackedy/ 
staged files) 

。 删除 档案 (尚未 加 入 么 引 的 档案 ) (tracked/ 
Unstaged flles) 

。 删除 档案 (已 经 加 入 寺 引 的 档案 ) (trackedy/ 


staged files) 


若 要 将 这 些 开 发 到 一 半 的 档案 建立 一 个 ' 暂 存 
版 ; ， 你 有 两 个 遗 择 : 


。git stash 会 将 所 有 已 列 入 追 跳 (tracked) 的 档 
案 建立 暂 存 版 

。git stash -u 会 包括 所 有 已 追 中 或 未 追 跳 的 
档案 ， 全 部 都 建立 成 暂 存 版 


主 : gcit stash 也 可 以 雹 成 git stash save， 两 个 
指令 的 结果 是 一 样 的 ， 只 是 save 参数 可 以 忽略 不 
打 而 已 。 


我 们 来 看 看 一 个 简单 的 例子 。 我 们 先 透 过 以 下 指令 
快速 建立 一 个 扒 有 两 个 版 本 的 Git 储存 库 与 工作 目 
色 : 


mKadam EdoaesseaShsaeme 
Carodlss asnsaems 
Oasisie 


EECINGOR TO ESDAE 
glLEEaOd 


gccemmania ma eemmaasew 


Eee 汪汪 忆 琴 臣 广 七 
册 册 玖 elsl 


Geemmanee ax SEEEESSEECOieeinte 


目前 的 “工作 目录 , 是 乾 汪 的 ， 没 有 任何 更 新 到 一 
半 的 术 案 : 


C:NXdit-stash-qemo>dgit 1od 

commit 95eff6b19a9494667985edq5da37427bb08b8cddq7 
Eee Neoggywnaangktgmaaaleeemz 

Date : OGAOSOO 


ENIEOERSASE EECOIOIEIEIAIE 
commit 346fadefadadq6eed2c562201pb5ca37dqle4Qdq26b26dq54 
AUehnhe : 轴 几 本 可 帮 和 eggynuanoglaomaaajeeeh 
Date : OILGNE 和 和 证 区 全 革 20EE SO 
CO 本 起 
CNgit=stasn=aQemo>git status 


ODSFaneh naee 


避让 站 下 贞 可 全 


GERNGTEEES 二 as 用 三 geeihie 过 Qi 
磁 奉 区 C 中 的 磁 碟 是 System 
磁 碟 区 序号 : 361C-6BD6 


cC:Ngit-stash-demo 的 目 销 


20137NOZTN 三 午 硬 08 二 下 7 DR 

2013/10/11 上 午 08:17 <DIR> 

2013/10/11 上 午 08:17 4 本 二 | 攻 六 七 
1 个 档案 4 位 元 组 


2 个 目 杀 9,800,470,528 位 元 组 可 用 


接著 我 新 增 一 个 b.txt， 再 将 a.txt 的 内 容 改 成 2， 如 
下 : 


全 


:Ngit=stash=aQaenmo>type ax 七 


C:ANdit-stash-dqemo>echo 2 > a. 七 X 上 t 


全 


:\dit-stash-dqemo>type 耻 .七 Xt 


BAopesieEKEOEIOSSEIeIOORNOSHNEE ee 


GERNGTEEES 二 as 用 三 geeihie 过 Qi 
磁 碟 区 C 中 的 磁 碟 是 System 
磁 碟 区 序号 : 361C-6BD6 


cC:Ngit-stash-demo 的 目 杀 


2 AU AREEE2EOSSSS5 DR 

2013/10/11 上 午 08:55 <DIR> 

2013/10/11 上 午 08:54 4 a. 此 xt 

2013/10/11 上午 08:55 遇 |E 均 七 
2 个 档案 11 位 元 组 


2 个 目 销 “9,704,288,256 位 元 组 可 用 


:Ngit=stash=aQesnmo>git status 
On branch masteL 
Changes not stadedq for commit : 
《Se 1 QTE OOEOUOEQaLEeTRRaT w1L1L1 


(sseaEehEekou 世 一直 TIE 演 丽人 忆 人 生 qusbCarcd 


moaqified: EN 


UntLracked files : 


(se aol dg <HLTLe> LOLnClLUode 2 what 


砷 : 井 : 霜 砷 井 井 : 砷 井 砷 井 井 0) 


GESAQE 


no_ changes adqdqedq to commit (use "dit adqddq" and/or 


现在 我 们 用 sit status 得 出 我 们 有 两 个 档案 有 释 
更 ， 一 个 是 a.txt 处 於 "not staged" 状态 ， 而 b.txt 
则 是 "untracked" 状态 。 


这 时 ， 我 们 利用 sit stash -u 即 可 将 目前 这 些 释 

更 全 部 储存 起 来 (包含 untracked 档案 )， 储 存 完 

后， 这 些 变 更 全 部 都 会 被 重 置 ， 新 增 的 档案 会 被 删 

除 、 修 改 的 档案 会 被 还 原 、 删 除 的 档案 会 被 加 回 

去 ， 让 我 们 目前 在 工作 目 杀 中 所 做 的 释 更 全 部 回复 

到 HEAD 状态 。 这 就 是 Stash 才 我 们 做 的 事 。 如 下 
所 示 : 


CNgit=stasn=-daemo>git stash = 
SavVedq working qirectory andq indqex State WIP on m 
GOmtkeenm 


HEAD is now at 95eff6b a.txt: set 1 as content 


C:Ndit-stash-dqemo>dit status 
# On branch masteL 


而 站 Workinoaeaeecteoeyctean 


在 建立 完成 ! 存 版 之 后 ，Git 会 顺便 才 有 我 们 建立 一 
个 暂 存 版 的 "参考 名 称 ，， 而 且 是 一 般 参 考 ， ， 
在 .git\refs\stash 储存 的 是 一 个 commit 物件 的 


绝对 名 称 ， 


CNOIEEEsEaSANEOQEmoT ENEEESN 
磁 碟 区 C 中 的 磁 碟 是 System 
磁 碟 区 序号 : 361C-6BD6 


cC:Nxgit-stash-dqemo\.git\refs 的 目 销 


2013/10/11 上午 08:57 过 站 下 民 到 
镶 07 生硬 08 二 57 <DIR> 


20TeTOATEESREOSSS7 <DIR> heads 

2013/10/11 上 午 08:57 41 stash 

01S OORIESETOSSTY 有 站 贡 R 肥 tags 
1 个 档案 41 位 元 组 


4 个 目 朱 9,701, 650,432 位 元 组 可 用 


我 们 用 可 工 七 已 志 世 一 1 人 一 已 5 证 己 ST 即 可 查 出 该 物件 
的 内 容 ， 这 时 你 可 以 发 现 它 其 实 就 是 个 具有 三 个 
parent (上 属 commit 物件 ) 的 commit 物件 : 


C:Ndit-stash-qemo>dgit cat-ftile -P stash 

tree 86cf41apb650dq8d0ce5fdad003bb7pb722a917438a2 
Parent 95eff6eb19a9494667985ed5ada37427bb08b8cadd7 
Parent b79c4650e72ad4627dq691a2dq6cfb192626e24e94 


Parent 9b4e4a100776783dqc76dl6ec3872235e6314Q15e3 
Eee 天 aeooeoysnhuancoegmaaa 上 eemmns 基 8 人 5 册 062 十 
人 Gin 王 性 Eee 本 eggsRnuangGgmaaaisecceomzalSsL45306 


WIP on master: 95eff6b a.txt: set 1 as content 


有 三 个 parent commit 物件 的 意义 就 在 於 ， 这 伯 特 
殊 的 暂 存 版 是 从 另外 三 个 版 本 合 供 进 来 的 ， 然 而 这 
三 个 版 本 的 内 容 ， 我 们 一 样 可 以 透 过 相同 的 指令 显 
示 其 内 容 : 


C:ANdit-stash-qemo>dgit cat-ftile -PP 95ef 

革 zree eba2ef4205738a5015fc47dq9cfe634d7dqp5eae466 
Parent 346fadefddq6eedq2c562201b5ca37dqle4dq26b26dq54 
WEEhO 汪 W 辣 本 <weoooy huanmeoelgmaaa 本 Com 本 ES 635 十 
Committer Wil1l <dqoggy.huangagmail.com> 138145063 


aextESeaisaS 本 已 @mfEermmite 


CNgit=stasn=-dqemo>git cat=-flile -pp b79c 

二 ree eba2ef4205738a5015fc47dq9cfe634d7dqp5eae466 
Parent 95eff6b1l9a9494667985edq5da37427bb08b8cddq7 
忆 让 七 生 吕 了 人 1 有 可 证 本 二 避让 8142B061 + 
COniniEteT LT <doogogvy huangkonmaEeceonm 8145306 


Inaqex on master: 95eff6b a.txt: set 1 as content 


C:Ndgit-stash-dqemo>dgit cat-ftile -PP 9b4e 

trzee b283bfe854b66756dd0f8ee96cab0c898193bpfda 

间 届 世 三 避 和 必 厅 二 OO 训 二 本 同属 放 训 站 > 有 SB062 + 
Gone 二 WaSE<awoaoeoss nuandoomanass com: SSL452306 


UntLzacked files on master: 95eff6b a.txt: set 1 ， 


从 上 述 执 行 结果 你 应 该 可 以 从 “讯息 纪 针 ,的 地 方 
清楚 看 出 这 三 个 版 本 分 别 代表 那些 内 容 : 
1. 原本 工作 目录 的 HEAD 版 本 
2. 原本 工作 目 色 壬 所 有 追 跳 中 的 内 容 (在 么 3 引 中 
的 内 容 ) 
3. 原本 工作 目 色 壬 所 有 未 追 跳 的 内 容 (不 在 勾引 
中 的 内 容 ) 


也 就 是 说 ， 他 把 " 原本 工作 目 色 的 HEAD 版 本 先 
建立 两 个 暂时 的 分 支 ， 这 两 个 分 支 分 别 就 是 ' 原本 
工作 目录 壬 所 有 追 跳 中 的 内 容 , 与 " 原本 工作 目 针 
壬 所 有 未 妃 跳 的 内 容 , 之 用 ， 姜 在 个 别 分 文 建立 了 
一 个 版 本 以 产生 commit 物件 区 且 给 予 预 设 的 log 
内 容 。 最 后 把 这 三 个 分 支 ， 合 供 到 一 个 参照 名 


称 , 为 stash 的 版 本 (这 也 是 个 commit 物件 )。 


不 俊 如 此 ， 他 还 把 整个 " 工作 目录 强迫 重 置 为 
HEAD 版 本 ， 把 这 些 变 更 与 新 增 的 档案 都 给 还 原 ， 
多 的 档案 也 会 被 移 除 。 


取 回 盾 存 版 本 


由 於 "工作 目 销 , 已 经 被 重 置 ， 所 以 变更 都 储存 
到 stash 这 里 ， 哪 天 如 果 你 想 要 把 这 个 暂 存 档案 取 
回 ， 就 可 以 透 过 5it stash pop 重新 了 合 侍 ， 回 
来 。 如 下 所 示 : 


C:ANdit-stash-dqemo>dgit status 
# On branch masteL 


而 忆 下 二 站 下 全 全 ea 


UntLrackedaq files : 


CNgit=stasnh=-oqaemo>ogit stash Dop 

# On branch masteL 

# Changes not stagedq for commit : 

非 ES 二 和 柄 
非 (SoumeRS 人 ED 二 二 作 各 下 过 本 Oddiicacd 
非 

非 modqified: EBD 

非 

非 

非 


人 what 


非 

非 ONIEXOE 

no_ changes adqdqedq to commit (use "dit adqddq" and/or 
Droppeqd refs/stashae{0} (0e5pb72c96fcf693e0402c40c 


执行 完 晤 ， 所 妥 初 的 工作 目 凶 状态 与 索引 状态 
都 会 被 迁 原 。 事 实 上 Git 骨 子 壬 是 透 过 ' 合 人 ,的 

功能 把 这 个 名 为 stash 的 版 本 给 合 供 回 目前 分 支 而 
已 。 最 后 ， 它 逮 会 自动 将 这 个 stash 分 支 给 删除 ， 


所 以 称 它 为 【 暂 存 版 】 非 党 贴 切 ! 


建立 多 重 暂 存 版 


Git 的 stash 暂 存 版 可 以 不 只 一 份 ， 你 也 可 以 建立 多 
份 暂 存档 ， 以 供 和 后 乱 使 用 。 不 过 ， 在 正音 的 开发 情 
境 下 ， 通 常 不 会 有 大 多 暂 存 版 才 对 ， 会 有 过 种 情 沈 
发 生 ， 主 要 有 两 种 可 能 : 


1. 你 的 开发 习惯 太 差 ， 半 致 累 积 一 堆 可 能 用 不 到 
的 暂 存 版 。 

2. 你 老 关 或 客户 插 单 ， 的 问题 十 分 启 重 ， 经 常 
改 到 一 半 就 被 迫 插 和 昔 。( 这 就 是 身 为 IT 人 的 Bl 
啊 ~~~XD) (BI = Business Intelligence 或 另 一 
属意 思 .… Well, you know.…) 


我 们 延续 上 一 个 例子 ， 目 前 工作 目 凶 的 状态 应 该 是 
有 两 个 档案 有 释 化 ， 我 们 用 sit status -s 取得 工 
作 目 杀 的 状态 (其 中 -s 代表 题 示 精简 版 的 状态 ) : 


CNgit=-stasn=-dqemo>git status =sS 
ME 上 exste 
CoREDeG 


现在 ， 我 们 先 建立 第 一 个 stash 暂 存 版 : 


C:Ndit-stash-dqemo>dgit stash save -U 
Savedq Working qirectory andq inadqex state WIP on m 


HEAD is now at 95eff6b a.txt: set 1 as content 


然后 透 过 git stash list 列 出 目前 所 有 的 stash 
清单 ， 目 前 仅 一 份 暂 存 版 : 


C:Ndit-stash-qemo>dit stash st 
stashaf{0}: WIP on master: 95eff6b a.txt: set 1 a 


而 且 你 可 以 看 到 建立 暂 存 版 之 后 ， 工 作 目 销 是 乾 滔 


的 。 此 时 我 们 在 建立 另 一 个 new.txt 档案 ， 半 且 再 
次 建立 暂 存 版 : 


CNgit=stasn=dqemo>git status 一 S 
C:Ndit-stash-dqaemo>echo 1 > new. 七 X 


CNgit=stashnh=dqaemo>git status 一 S 


ZENDIEO GE 


C:Ndit-stash-dqemo>dgit stash save 一 U 
Savedq workindg qirectory andq indqex state WIP on m 
neem 世 


HEAD 1Is now at 95eff6b a.txt: set 1 as content 


我 们 在 再 一 次 git stash 1list 就 可 以 看 到 目前 有 
两 个 版 本 : 


C:ANdit-stash-qemo>dit stash ist 
stashaf{0}: WIP on master: 95eff6b a.txt: set 1 a 
stashae{f1}: WIP on master: 95eff6b a.txt: set 1 a 


你 应 该 会 很 纳 交 ， 都 没有 自 订 的 主 解 ， 过 了 继 天 不 


就 忘记 这 两 个 暂 存 档 各 自 的 修改 项 目 吗 ? 没 错 ， 所 
以 你 可 以 自 订 "看 存 版 , 的 纪 杀 讯 息 。 我 们 透 
过 9it stash Save -u <messade> 指令 就 可 自 


订 暂 存 版 的 主 解 : 


C:Ndit-stash-dqemo>dit stash -Ph 
Sage 本 本 二 下 EN S 荆 SN 全 世人 雪 忆 记 攻 下 CS 汪 
SEONSSEAVenesEESESON ESSEERSIE 


or: g9it coreNgit-stash qdqrop [-d|--duiet] [<st 


or: git coreNgit-stash ( pop | apply ) [--indq 

or: dit corexdgit-stash branch <branchname> [< 

OF 1OENOEEESEaiSA SS7e 汪 了 攻 二 记 二 IE 亿 [-Kk|==- 
-ul--include-untracked] 


GOEEECoOeNOREE SSEECEES 


CNgitE=stash=oqaemo>git stash Pop 
Already up-to-dqatel 
# On branch masteL 


丰 兴 [页 二 下 二 全 帮 各 癌 下 直下 es 


非 (SSE 是 坟 人 TS 和 区 OCSe 汪 10|nat 
非 
左 mew .七 X 七 


nothing added 七 commit pbut untracked files Pres， 


Droppeqd refs/stasha{0} (5800f37937aea5fb6alaba0d 


C:Ngit-stash-demo>git stash save -u "新 增 mlew .txt 


Savedq WoOLTKing qirectory and inadqex state Onl maste 


HEAD is now at 95eff6b a.txt: set 1 as content 


C:ANdit-stash-qemo>dit stash ist 
stashae{0}: on master: 新 增 new.txt 档案 


stashae{f1}: WIP on master: 95eff6b a.txt: set 1 a 


这 时 ， 如 果 你 直接 执行 sit stash pop 的 话 ， 他 会 
取 回 最 近 的 一 笔 暂 存 版 ， 也 就 是 上 述 例子 

的 stashe{0} 这 一 项 ,站 且 把 这 一 笔 删 除 。 另 一 种 
取 回 暂 存 版 的 方法 是 透 过 sit stash apply 指令 ， 
唯一 差别 则 是 取 回 该 版 本 (其 实 是 执行 合 伴 动 作 ) 

和 后， 该 暂 存 版 迁 会 留 在 stash 清单 上 。 


如 果 你 想 取 回 “特定 一 个 暂 存 版 ， 你 就 必须 在 最 
后 指名 stash id， 例 如 stashet1)} 这 样 的 格式 。 例 
如 如 下 和 范例， 我 使 

用 osit stash apply "stasheflln 取 回 前 一 个 暂 


存 版 ， 但 保留 这 版 在 stash 清单 里 : 


C:ANXdit-stash-qemo>dit stash ist 
stashaef{0}: on master: 新 增 new.txt 档案 


stashae{f1}: WIP on master: 95eff6b a.txt: set 1 a 


C:Ndit-stash-qemo>dgit stash app1Ly "stashQG@lfl)}n 


# On branch masteL 

# Changes not stagedq for commit : 

非 全 GePREEEEie 人 人 oOENES IE 呈 生 证 才 本 
非 (SS 二 本 RS 人 Ko 二 和 < 人 1 之 ES 机 Carada 
非 

非 modqified: ES 

非 

# Untracked files: 

非 GOSeRga 人 Sa 是 雪 人 IE 二 EeeeEanlnat : 
非 

非 eic 


no _ changes adqdqedq to commit (use "dit adqddq" and/or 


C:ANdit-stash-qemo>dit stash st 
stashae{f0}: on master: 新 增 new.txt 档案 
stashaf{1}: WIP on master: 95eff6b a.txt: set 1 a 


如 果 确 定 合 供 正 确 ， 你 想 删 除 stashel1l 的 话 ， 可 
以 透 过 dit stash qrop "stashefllu 将 特定 暂 存 


版 删除 。 


C:Ndit-stash-dqemo>dgit stash Qrop "stasheG@l{f1)n" 
Dropped stashal1Ll} (118cb8ayc0b763c13435990?7?7d79f 


C:ANXdit-stash-qemo>dit stash 1ist 


stashe{0}: on master: 新 增 new.txt 档案 


如 果 想 清理 掉 所 有 的 暂 存 版 ， 直 接 下 
过 ait stash clear 即 可 全 部 删除 。 


C:Ndit-stash-qemo>dit stash ist 


stashae{0}: on master: 新 增 new.txt 档案 


C:NXdit-stash-dqemo>dgit stash clear 


C:ANdit-stash-qemo>dit stash ist 


今日 小 短 


Git 的 stash ( 暂 存 版 ) 机 制 非常 非常 的 实用 ， 尤 其 是 
在 IT 业界 插 单 灰 重 的 工作 环境 下 (不 只 台湾 这 样 ， 
世界 各 地 的 IT 业界 应 该 也 差不多 )， 这 功能 完全 为 
我 们 量 身 打造 ， 非 党 的 贴心 。 在 Subversion 和 里 就 没 
有 像 Git 这 诬 简 单 ， 一 个 指令 就 可 以 把 工作 目 杀 和 与 
索引 的 状态 全 部 存 起 来 。 


本 篇 文章 也 试图 透 过 指令 了 解 stash 的 核心 机 制 ， 


实 就 是 简单 的 分支; 与 合 伴 ， 而已， 由 此 可 
知 , 整套 Git 版 本 控 管 机 制 ， 大 多 是 以 分支: 与 
合 供 ， 的 架构 在 运作 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git stash 


git stash -U 


git stash Save 


git stash Save -U 


git stash list 


git stash pop 


git stash apply 


git stash pop "stash@{id}" 


git stash apply "StashQO{id}” 
git stash drop "stash@Q{id}"” 
git stash clear 


参考 连结 


*。 BASIC SNAPSHOTTING 


。 HOME 
。 回 目录 


: 认识 Git 物件 的 相对 名 称 


: Git for Windows 遗 项 


二 几 一 一 


6 又 上 引 . 


第 14 天 : Gitfor Windows 


选项 设 定 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/14.md 


使 用 Git for Windows 指令 列 工具 绝对 比 透 过 GUI 
工具 操作 来 的 有 效率 ， 原 因 就 在 於 你 可 以 把 许多 重 
得 的 版 控 工 作 透 过 指令 自动 化 ， 或 将 复 订 的 标准 作 

业 流 程 (SOP) 转 化 成 简单 的 指令 操作 。 本 篇 文章 将 
分 享 儿 则 使 用 Git for Windows 指令 列 工具 的 小 技 
瑟 。 


关於 Git 指令 列 工具 的 遗 项 设 定 


在 Git 指令 列 工 具 实 ， 有 许多 " 跑 项 ,可 以 设 定 

如 同 我 们 使 用 GUI 工具 通常 都 会 有 [工具 ] -> [偏好 
设 定 ] 一 样 ， 可 以 微调 指令 执行 时 的 一 些 行为 。 最 常 
见 的 ， 当 然 就 是 首次 使 用 Git for Windows 的 时 
候 ， 必 须 设 定 user.name 与 user.email 选项 ， 汽 
有 这 两 个 导 项 设 定 ， 你 速 执行 sit commit 的 权力 


都 没 


要 列 出 目前 设 定 在 Git for Windows 工具 下 的 所 
和 号 ， 可 以 使 用 gj 七 “CO 瑟 在 二 可 一 一 外 工 S 七 命令 ， 如 下 
图 示 : 


模 CNWindows\system32NXcmd.exe 


:Ngit-hbranch-demo>git conf ig 一 -1ist 
oke .SUymlinks=false 
OFe -autocr1lf =tFue 

-diff=auto 

“ -Status =auto 

“- branch=auto 

-intekactiue=tFue 


ittp-.sSSJlcainfo=Ahbincuk1-ca-hbundqdle .ct 
endemail.-smtpsekuer=/hbinmsmtpb -exe 


iff .astextpblain .textconuv=astextplain 


-name= 则 il1 

-email= gmail.com 
-autocokkect= 并 

ve -auUtocF1TEF =tFue 

ve .FepDpositorkruyfokrmatueksion=g 

“ee -filemode=false 

e .bare=false 

ve .1ogallrefupdates=thue 

ve .Symlinks=false 
.Ignokecase=tkFue 

*e .hidedotfiles=dotGiton1y 


主 : 由 於 网 路 上 大 部 分 的 Git 文章 ， 都 介绍 Linux 
或 Mac 电脑 的 执行 环境 如 何 设 定 ， ee 
Windows 平台 的 设 定 教学 ,除了 储存 

径 比 较 不 一 柑 之 外 ， 0 
罗 


若 想 查 询 所 有 可 用 的 遗 项 , 有 哪些 ， 可 在 命令 提 


示 字 元 下 执行 9it helpPp confid 即 可 是 示 完 整 的 文 
件 褒 明 或 可 过 到 git-config(1) Manual Page 页 面 查 
看 。 


储存 Git 选项 设 定 的 三 个 地 方 


1. 系统 属 级 ( --system ) (System-level 
configuration) ( 设 定 於 整 台 和 电脑， 通用 於 本 机 
所 有 使 用 者 的 预 设 值 ) 


上 


如 果 和 要 列 出 所 有 设 定 在 "系统 属 级 , 的 "“ 跑 
项 ，， 可 以 执 

行 git config --lList --systenm 命令 ， 也 就 
是 额外 加 上 --system 即 可 节选 出 关於 系统 属 
级 的 遗 项 设 定 ， 如 下 图 示 : 


画 CNWindows\system32N\cmd.exe 


vehbase -autosqduash 


所 有 的 “系统 属 级 , 的 选项 设 定 预 设 会 储存 


在 C:NProdgram Eliles (xX86)NGitNetcxdgitconfid 


这 个 档案 里 。 不 过 ， 如 果 你 电 及 使 用 的 作业 系 
统 是 Windows Vista 以 上 版 本 ( 含 Windows 7 
与 Windows 8 作业 系统 ) 又 同时 艇 用 上 使 用 者 
帐户 控制 ，(UAC; User Access Control) 的 
话 ， 那 庶 这 个 路 径 将 会 


是 s$LOCRALAPPDATASNVirLualLStoreNProgram Files ， 


(这 个 路 径 位 於 使 用 者 的 目 杀 下 ) 。 会 有 这 层 改 
变 的 原因 就 出 在 UAC 限制 了 一 般 程 式 存 取 
“系统 资料 来 ， 中 的 档案 权限 ， 半 致 你 扰 法 在 
使 用 sit config 写 入 选项 设 定 到 这 个 设 定 档 
里 。 在 Windows Vista 以 上 版 本 ， 实 作 了 一 套 
VirtualStore 相 容 性 技术 ， 让 你 的 程式 试图 鼓 
入 档案 的 同时 ， 也 可 以 写 入 成 功 ， 不 过 写 入 的 
路 径 色 是 不 同 的 ， 这 点 必须 特别 注意 。 


这 个 Windows 内 建 的 VirtualStore 相 容 性 技 
了 术 ， 其 技术 文件 非 党 稀有， 似乎 代表 著 很 少 人 
知道 这 个 东西 ， 但 这 技术 确实 可 能 会 让 使 用 者 
产生 困 摄 。 例 如 ， 我 们 用 “ 一般 方式 执行 命令 
提示 字 元 , 与 用 ' 以 系统 管理 员 身 分 执行 命令 
提示 字 元 ,， ， 所 塌 入 的 “系统 屋 级 遗 项 , 是 不 
能 互通 的 。 换 句 话 说 ， 如 果 你 用 ' 以 系统 管理 
员 身 分 执行 命令 提示 字 元 , ， 如 下 图 示 : 


关节 (O) 
呈 以 RE ， 
党 工作 列 取 满 和 和 还 遇 


内 容 四 


然 和 后 执行 git config --svstem --1List 先 列 
出 所 有 参数 ， 我 们 可 以 发 现 目前 

的 core.autocrlf 参数 为 true， 接 著 我 将 系 
统 层级 的 core.autocrlf 修改 为 false， 最 和 后 
执行 git config --system core.autocrlf 

读 出 COGEeG va 七 DC 二 的 内 容 ， 你 可 以 看 至 我 

们 已 经 把 core.autocrlf 选项 修改 为 false 

了 。 如 下 图 示 : 


画 系统 管理 遇 : 命令 提示 字 元 


:WindowsNsystem32>git config --System -1ist 
Core -Symlinks=false 
De -autocF]E=tFue 


endemail.-smtpsekuer RS eXxe 
iff .astextplain .textconu=astextplain 
vehbase -autosdquash=thue 


:WindowsNsystem327>9it config 一 -System coe -autock]lf false 


:NindowsNsystem327git config --SyStem coFe .autocr1lf 
alse 


:WindowsNsystem32> 


再 来 我 们 用 一 般 权 限 执 行 "命令 提示 字 元 ， 


地 往 此 和 式 从 工作 列 取 洁 条 并 
| 辆 羡 疼 所 有 视 富 


然后 执 
行 9it confid --System core.autocr1lE 读 


出 core.autocrlf 的 内 容 / 这 时 你 可 以 看 到 
我 的 <ore.autocrlf 选项 值 也 是 false， 目 
前 区 没 有 发 现任 何 问 题 。 不 过 这 时 如 果 你 再 执 
行 dit confid --System core.autocr1lLf 七 Yue 
把 core.autocrlLf 遗 项 设 定 改 回 true 的 话 / 


在 目前 的 环境 下 也 没 问 题 : 


人 
画 命令 提示 字 元 
:N\?>9it config 一 -SUStem coFke -autocr]f 

alse 

:Nz>9it config 一 -SUyStem coFe .autocF1lf trFue 


:N?9it config 一 -SUyStem coFe -autocr]f 
FUe 


:\> 


但 如 果 我 们 重新 “以 系统 管理 员 身 分 执行 命令 
提示 子 元 」 ， 再 输入 一 


次 G9iIit ConflIg 一 一 System COFe .autocELI 读 


出 core.autocrlf 的 内 容 ， 你 会 发 现 其 玩 项 
值 竟然 为 false， 这 个 所 谓 的 “系统 层级 , 设 
定 薄 没有 真 的 套用 到 所 谓 的 “系统 层级 ，， 所 
以 你 日 后 使 用 Git 的 过 程 中 发 现 上 怪 怪 的 1 状 
沈 ， 或 怀疑 Git for Windows 这 工具 好 像 有 
Bugs， 但 事实 上 这 跟 工具 一 点 关 人 都 没有 ， 是 
作业 系统 的 问题 ! 


画 系统 管理 员 : 命令 提示 字 元 


ft Uindows [有 版 本 6.2- 9299] 
《c》> 2812 Microsoft Corporation- 著作 楼 所 有 ， 壮 保 


SNSyStem32>git config SUStem cokFe -autock 


:indows\systemn32>。 


如 果 你 的 Windows 登入 帐号 为 will 的 话 ， 
这 
gsLOCRLRAPPDRATRASNViLrLuaLStoreNProgram Files 
径 就 会 自动 展开 
。 ES 
也 代表 著 ， 沼 你 在 “一般 权限 , 下 款 行 "命令 
提示 字 元 ， , 闻 且 透 过 9it confid --System 
设 定 “系统 层级 ， 遗 项 ， 那 该 设 定 将 会 变 成 
只 有 自己 , 能 终 套 用 而 已 ， 不 会 套用 到 本 机 
其 他 使 用 者 身上 。 


结论 : 各 要 设 定 " 系统 层级 , 遗 项 ， 请 务必 用 


【 以 系统 管理 遇 身 分 执行 】 的 方式 艇 用 命令 提 
示 字 元 ， 然 后 再 执行 git config 命令 ， 才 能 
写 入 正确 的 档案 位 置 。 


补充 资讯 : VirtualStore - Inside Windows Vista 
User Account Control 


. 使 用 者 层级 ( --global ) (User-level 
configuration) ( 设 定 於 目 前 登入 的 使 用 者 ) 


如 果 和 要 列 出 所 有 设 定 在 “使 用 者 属 级 , 的 " 遗 
项 ，， 可 以 执 

行 cit config --list --global 命令 ， 也 就 
ee --global 即 可 筋 跑 出 关於 使 用 者 
层级 的 遗 项 设 定 ， 如 下 图 示 : 


上 


画 命令 得 示 字 元 


关於 "使 用 者 屋 级 , 的 选项 设 定 预 设 会 储存 

在 sUsERPROFILESN\.gitconfig 

或 c:\Users\< 使 用 者 帐号 >\.gitconfig 这 个 档 

案 壬 。 由 於 枚 案 储存 在 自己 的 使 用 者 资料 夹 
下 ， 没 有 像 “系统 层级 设 定 时 有 权限 问题 。 


CD 


一 般 来 说 ， 我 们 通常 会 把 user.name 

与 user.email 选项 设 定 在 "使 用 者 屋 级 ，， 
例如 以 下 设 定 和 范例 (请 换 成 你 自己 的 姓名 和 与 电子 
邮件 地 址 ) : 


杂 本 生生 人 and 


OnECOTEROE OObaSens 有 Sa VN 汪 RNEXSamD1 


还 有， 由 於 " 使 用 者 履 级 , 顾 名 思 闵 就 是 "使 
用 者 自己 专用 的 地 方 , ， 所 以 通常 我 们 也 会 把 
个 人 化 :4 的 环境 设 定 都 设 定 在 这 壬 ， 这 部 分 
本 文 稍 后 就 会 分 享 关 个 环境 设 定 的 技巧 。 


. 储存 区 层级 ( --Local ) (Repository-level 
configuration) ( 设 定 於 工作 目 销 下 
的 .G9itNconfig 设 定 档 中 ) 


如 果 要 列 出 所 有 设 定 在 ' 储存 区 屋 级 , 的 上 跑 
项 ， ,可 以 执行 git config --1ist --1local 
命令 ， 也 就 是 额外 加 上 --1local 即 可 入 导 出 关 
於 储存 区 层级 的 遗 项 设 定 ， 如 下 图 示 : 


画 命令 提示 字 元 


储存 区 属 级 的 遗 项 设 定 档 预 设 季 人 存在 你 Git 工 
作 目 凶 的 .sit\config 设 定 档 中 ， 这 档案 会 
在 你 建立 本 地 储存 库 或 适 过 sit clone 取得 训 
端 储存 库 时 自动 建立 ， 如 果 你 要 定义 将 ' 特定 
工作 目录 , 才 要 有 的 选项 设 定 ， 则 可 以 直接 将 
遗 项 设 定 储存 在 这 里 。 


Git 选项 设 定 的 误 用 顺序 


由 於 设 定 Git 遗 项 时 可 以 套用 三 种 不 同 的 属 级 ， 不 
同 的 属 级 下 可 以 设 定 相同 名 称 的 遗 项 ， 但 要 以 哪 一 
个 属 级 的 设 定 入 准 呢 ”事实 上 Git 指令 列 工具 在 执 
行 时 会 依据 以 下 优先 顺序 进行 套用 : 


1. 先 套 用 系统 属 级 (优先 权 最 低 ) 
2. 再 套用 使 用 者 屋 级 
3. 再 套用 储存 区 属 级 (优先 权 最 高 ) 


士 几 一 


也 就 是 说 ， 你 如 果 在 系统 层级 曾经 设 定 
过 core.autocrlf 遗 项 ， 然 后 在 使 用 者 屋 级 又 重新 


定义 过 一 次 那 床 最 终 会 套用 的 COre .autocLr1] 工 跑 


项 值 将 会 是 使 用 者 屋 级 , 的 设 定 值 。 


不 过 ， 耕 你 的 执行 环境 各 是 使 用 Windows Vista 以 
上 姜 刻 用 UAC 使 用 者 存 取 控 制 ， 而 且 逮 只 用 “一 
般 权 限 , 执行 这 些 Git 命令 的 话 ， 读 取 和 与 套用 的 顺 
序 会 多 一 个 判断 : 


1. 套用 系统 属 

级 : cC:\Program Eiles (x86)\GitNetcNdgitconfig 
2. 套用 系统 属 

级 : sLOCALAPPDRATASNVirtualStoreNProgram Files 
3. 套用 使 用 者 属 级 : sUsERPROFILES\.gitconfig 
4. 套用 储存 区 属 级 : .sit\config 


若 你 想 要 知道 目前 的 工作 环境 最 终 套 用 的 选项 设 定 
有 哪些 ， 直 接 执 行 scit config --list 即 可 以 取得 
所 有 ' 已 设 定 , 的 遗 项 设 定 清单 : 


亚 CNWindows\system32Ncmd.exe 


:Ngit-hbranch-demo>git conf ig 一 一 1ist 
oke .SUymlinks=false 

De .autocr1lf =tFue 

0O1lor .diff=auto 

olor .status=auto 

olor -branch=auto 

olor -intekractiue=thue 
ipack .packsizelimit=29 
he lp .fokrmat=htm1l 
httpb-.sslcainfo=Ahbincur1-ca-bundle .crFt 
endemail.-smtpsekuer=/hbinmsmtpb -exe 
iff .astextpblain .textconuv=astextplain 
vehbase .autosduash=tFue 

ISerkr -name= 则 ill 

ISer -email= gmail.com 
he lp .autocoFFect=T1 

OFe .autock1lf =tFue 


oke .kepositoruyforkrmatuerkrsion=g 
oke -filemode=false 

oke .bare=false 

DoFe .logallrefupdates=thue 

oke -.Symlinks=false 

oOFe .iignokecase=tkhue 

okre .hidedotfiles=dotGiton1yv 


GCCoDLO SSL 
Eee 
ge 本 eco、 咯 RESL 本 Ch 
Eee 


。 取得 特定 遗 项 值 


qiEEeconTOaRceETOESscCEnonRconRTOEname] 


9TEECONATO 硬 WS 全 基 二 有 ame 


= 


CDOTELOUUEC GREEN Eeesnamne] [c 


opennronSSTERSamEa WINUSO 


9it config user.email "willQexample.comn" 


。 删除 特定 遗 项 设 定 


cpuEeEeong Unset System [config sectio 
REeG RUISISEE OKoOaiaFeGhEETEoEEBectTC 
oemEngEE USSEE 一 OSIECCNEEEoaEBect1C 


选项 设 定 档 的 内 容 结 构 


Git 选项 设 定 的 档案 内 容 其 实 格 式 都 一 样 ， 我 们 试 著 
开启 一 个 使 用 者 屋 级 下 的 设 定 档 看 看 


( 8s$USERPROEILESN.gitconfig ) : 


BEile Edit Viesw Sesttings 2 


口 盛 杞 加 | 号 人 | 关 抽 急 | 准 二 | 轩 | 委 尽 | 国 刀 | 玉 
1 [user] 

2 name = Will1 

3 email = wil11eexamp1e.com 
4 [help] 

5 autocorrect = 工 

6 


我 们 从 上 图 可 以 看 到 ， 中 括号 ( [和 与 ] ) 所 包含 的 
是 一 个 "区 段 名 称 ，， 代 表 某 一 群 设 定 档 的 分 类 ， 
而 其 他 的 内 容 则 是 一 组 Key/Value 的 对 应 设 定 。 通 
站 qit config 命令 来 操作 人 这些 选 项 设 

, 但 你 其 实 也 可 以 直接 用 Notepad 编辑 这 些 档 
本 可 以 达到 完全 一 样 的 效果 。 如 果 想 了 解 有 哪些 
遗 项 可 用 ， 可 以 在 命令 提示 字 元 下 执 
行 9it helpPp confid 即 可 显示 褒 明 文件 。 


名 
有 没有 觉得 每 次 用 git 打 指 令 很 喔 嗪 ， 尤 其 是 
经 常 使 用 
的 可 并 七 8 七 全 US， 可 1 七 -CarmmIi 上 可 七 QQ 
或 sit 1log 等 指令 ， 有 时 候 还 要 外 加 一 些 额外 


的 指令 参数 ， 每 次 这 样 输入 膛 真 的 挺 烦 的 。 其 
实 你 可 以 透 过 指令 别名 的 设 定 ， 让 指令 输入 的 


更 短 一 些 。 


首先 ， 我 们 先 设 定 一 些 我 常用 的 Git Alias 设 
定 ， 指 令 如 下 : 


ONEE 本 eeGOJEOR Oils 本 CO Checkeut 


REEECGXG)DEONON 二 用 Eee 天 二 二 汪汪 生僻 下 Commit 
gg 和 GO TO 本 三 四 由 @a 可 吉本 二 要 = 七 Statup 
piERIGeionaaie 攻 二 二 Ge 有 RoleEEHL 
GE OO 人 二 二 可 下 Ga 这 王 下 达 本 四 改 branch 
Se ee 


由 晤 SG 加 汪 革 全 司 


Eco 下 GE GilG 世 ai 
GasEGehnOEeOilieloaih 


ias.sts "status 一 sS" 


人 亿 中 OO RE 000) 
睛 - 
册 
OU 


dasecomGEE 一 GOliOloaiaaSRENGSEE2CatsEiLlLe 一 
gpEEeOTOg 下 Ga aaSRsOumio 昌 写 esilLs: 一 
GTRECG 人 下 汪 扣 大 加 让 ii 三 放 疝 过 汪 Ke) "1og 上 上 -one1 
GTRE 和 CO 让 于 是 加 中 ai 下放 本 二 坟 汪 放 同时 Oo 汪 一 D 工 人 七 七 
Ra TOOSEE=Uraph 


二 几 一 二 -二 


ji 和 在 元 违 


些 "指令 别名 , 后， 如 果 今 后 你 要 显 


示 工 作 目 录 状 态 ， 原 本 你 要 输入 完整 
的 sit status， 现 在 你 可 以 只 输入 sit st 
即 可 完成 。 如 果 你 要 显示 简易 版 的 状态 资讯 ， 


以 前 你 要 输入 sit status -s 才能 完成 ， 现 
在 你 只 要 输入 sit sts 即 可 完成 。 要 显示 单行 
的 历史 纪 人 录 ， 现 在 也 只 要 输 

入 git lo git 11 或 git 19 就 可 以 完成 。 
是 不 是 相对 的 简单 很 多 呢 ! :-) 


指 定 预 设 & 文字 编辑 器 


预 设 Git for Windows 在 执行 sit commit 的 
时 候 ， 会 开启 Vim 编辑 器 。 如 果 你 想 切 换 成 记 
事 本 的 话 ， 可 以 透 过 以 下 指令 完成 设 定 : 


9TEEREConEOEoeobaceconeeantEoenoebaaq .ex 


如 果 想 指 定 Notepad++ 党 当 为 主要 编辑 器 器 呈 的 
话 ， 可 以 透 过 以 下 指令 完成 设 定 (请 自行 修改 
执行 档 路 径 ) : 


9it config ==g9lLobal core saitor "NTC:\Prog 


当然 ， 你 想 换 成 Sublime Text 也 是 没 问 题 的 ， 
只 要 把 执行 档 路 径 雹 对 即 可 ! 


。 直接 编辑 设 定 档 


有 时 候 直接 编辑 设 定 档 会 比 下 指令 来 的 方便 
些 ， 所 以 如 果 你 想 要 直接 和 从 指令 列 开 属 编 辑 设 
定 档 的话 ， 可 以 参考 以 下 指令 


jaReSexeiaaBakeh edit SYStem 
全国 ein 二 ee = wh 区 Ee 民 lex 加 有 
人 


如 此 一 来 可 以 省 去 开启 档案 总 管 ， 东 找 到 路 径 
后 再 开启 档案 的 繁 玉 步 灵 。 


。 自动 辨识 CRLF 字 元 


在 Windows 底下 ， 建 议 最 好 打开 core.autocrlf 
遗 项， 让 Git 将 档案 储存 进 物 件 储 存 区 ( object 
storage ) 时 ， 可 以 自动 坎 滤 所 有 CR 子 元 ( \ 
)， 以 利 Git 专案 能 更 容易 跨 平 台 ， 让 在 Linux 

与 Windows 平台 做 开发 的 人 都 能 顺利 使 用 Git 
版 本 控 管 。 


GEEeONnTO 二 sgiooail 旺 CGOe 要 REOCISEREE Se 


笔者 曾经 写 过 一 篇 Git 在 Windows 平台 上 处理 
扬 行 字 元 (CRLF) 的 注意 事项 的 文章 ， 建 议 各 
位 可 以 看 看 。 


。 自动 订正 打 错 的 参数 


输 竟 我 们 是 用 指令 列 工具 再 输入 ， 打 错字 在 所 
订 免 ， 例 如 你 输入 sit statsu ( 打 错 字 了 ) ， 
若 衣 用 上 自动 订正 ， 遗 项 , 则 Git 工具 会 自动 
修正 为 sit status 站 成 功 执 行 ， 让 你 不 用 重 
打 一 次 。 以 下 是 开 艇 自动 订正 选项 的 指令 : 


gconroeolocal neo acocceeet| 工 


。 启用 讯息 颜色 


预 设 Git for Windows 的 “系统 属 级 ， 设 定 中 
已 经 艇 用 了 讯息 颜色 功能 ， 但 如 果 你 不 小 心 关 
于 的 话 ， 可 以 用 以 下 指令 开 刻 : 


9 下 EECOnEEOE SYSem 硬 coconsuuaec 


。 自 订 commit 讯息 和 范本 


每 当 我 们 输入 sit_ commit 的 时 候 ， 都 会 跳出 
一 个 文字 编辑 视窗 ， 让 我 们 输入 本 次 要 
commit 的 纪 杀 讯 息 ， 但 每 次 都 需要 重头 输入 
讯息 。 在 转 队 中 ， 你 可 能 会 希望 大 家 共用 一 个 
[文字 箔 本 ， 7 好 让 大 家 在 Git Commit 的 时 
候 都 能 络 填 写 必 要 的 栏 位 或 资讯 。 
如 果 和 要 指令 commit 讯息 范本 ， 必 须 先 建立 一 
个 文字 和 范本 档案 ， 假 设 我 放 在 G:git-commit- 


template .txt 


接著 透 过 以 下 指令 ， 设 定 commit 讯息 和 范本 的 


ConmESEE OCRCSOmnatREemEiiSEe2B:ANdit 


最 和 合 执 行 glit Commit 所 跳出 的 于 讯息 名 晴 辑 视窗 
就 会 有 预 设 内 容 了 : 


画 系统 管理 遇 : 命令 提示 字 元 - git commit 


anch-demo>type g:Ngit-commit-template .txt 


anch-demo>git config -local comnmit.template "G:Ngit-commit-te 


这 Gxgit-branch-demovgitCOMMIT_EDITMSG - Notepad2 (Admin 
Ele Edit View Settings 2 


外 本 | 的 专 | 团 | 和 &I 国 败 | 形 


1 
3 
| 4 和 音 PTease enter the Commit message for your changes。 Lines 5 
| 5 ## With '#" will1 be ignored，and an empty message aborts the 
| 65 #On branch master 
| 7 # Changes to be committed: 
8 (use “9git reset HEAD <file>... ”to unstage) 
9 


各 位 不 知道 有 没有 注意 到 ， 我 故意 用 --1local 
参数 ， 将 设 定 储存 在 “储存 库 层 级 ， 下 

( .git\config )， 主 要 原因 就 是 ' 讯息 范本 ， 

有 时 候 是 跟著 专案 , 走 的， 不 同 的 专案 可 能 
会 想 套 用 不 同 的 讯息 范本。 如 果 你 跟 我 有 相同 
的 需求 ， 就 可 以 套用 --1local 参数 。 否 则 ， 你 
也 可 以 套用 --global 直接 套用 在 使 用 者 层级 


今日 小 舌 


今天 介绍 的 Git for Windows 遗 项 设 定 不 是 很 常 

用 ， 通 常 也 只 需要 设 定 一 次 就 没事 了 ， 但 上“ 工 欲 善 
其 事 、 必 先 利 其 器 ， 先 把 环境 、 遗 项 都 给 设 定 
好 ， 你 将 可 大 幅 减 少 Git 版 本 控 管 的 花费 时 间 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git config --list 


git config --list --System 


git config --list --global 


git config --list --local 


git config --edit --System 


git config --edit --global 


git config --edit --local 


git config [config_section.config_name] 


git config [config_section.config_name] 
[config_value] 


。git config --unset --System 
[config_section.config_name] 


。git config --unset --global 
[config_section.config_name] 


git config --unset --local 
[config_section.config_name] 


git config user.name 

git config user.email 

git config user.name "Will Huang” 

git config user.email "will@example.com" 
git config --global alias.co checkout 
git config --global alias.ci commit 

git config --global alias.st status 

git config --global alias.sts "status -S" 
git config --global alias.br branch 

git config --global alias.re remote 

git config --global alias.di diff 

git config --global alias.type "cat-file -ft 


git config --global alias.dump "cat-file -p" 


git config --global alias.lo "log --oneline" 


git config --global alias.l| "log -- 
pretty=format:%h %ad | %s%d [%oCgreen 
%an%eCreset] --graph --dqate=short" 


git config --global alias.Ig "log --graph -- 
pretty=format:%Cred%ho%oCreset %ad | 
%C(yellow)%d9%oCreset %s 
%Cgreen(%cr)%Creset [%Cgreeno2ean 
%cereset] --abbrev-commit --date=short" 


git config --global core.editor notepad.exe 


git config --global core.autocrlf true 


git config --global help.autocorrect 1 


git config --System color.ui auto 


。git config --local committemplate "Gxgit- 
commit-template .txt" 


参考 连结 


。 Git - Alias 


。 11. Aliases | Git How To 
。 7.1 Customizing Git - Git Configuration 
。git-config(1) Manual Page 


*。 HOME 

。 回 目 针 

。 前 一 天 : 暂 存 工作 目 杀 和 与 系 引 的 释 更 状态 

。 下 一 天 : 标 敏 - 标记 版 本 控制 过 程 中 的 重要 事 
作 


第 15 大 : 标 敏 - 标记 有 唉 本 控 
出 过 昌 程 中 的 重要 事件 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/15.md 


在 使 用 Git 版 本 控 管 的 过 程 中 ， 会 产生 大 量 的 版 
本 ， 随 著 寒暑 易 节 、 物 换 星 移 ， 在 这 大 多 的 版 本 之 
中 ， 一 定 会 有 一 些 值 得 我 们 纪 和 人 的 几 个 重要 版 本 ， 
这 就 是 5 标 毓 ! (Tag) 能 攻 我 们 做 的 事 。 


关於 标 答 (Tag) 的 基本 概念 


基本 上 ， 标 敏 的 用 途 就 是 用 来 标记 某 一 个 ' 版 本 ， 
或 称 入 "commit 物件 ， ， 以 一 个 好 记 的 名 称 , 来 
旬 助 我 们 记 悍 【 某 个 】 版 本 。 


Git 标 敏 (Tag) 所 有 两 种 型 驴 ， 这 两 种 类 型 分 别 是 : 


。 到 量 标 答 (lightweight tag) 
入 


。 标示 标 敏 (annotated tag) 


我 们 在 【第 11 天 : 认识 Git 物件 的 一 般 参 照 与 符号 
参照 】 文 章 中 有 提 到 “一般 参 照 , 包含 了 ' 标 毓 名 

称 , 这 项 ， 这 里 的 ' 标 敌 名称, 就 是 所 谓 的 ' 轻 量 

系 猎 ， (lightweight tag) 。 所 以 “ 轻 量 标 毓 ， 可 以 褒 
是 某 个 commit 版 本 的 “别名 :4 而 已 ， 是 一 种 ' 相 

对 名 称 , 。 


标示 标 毓 ，(annotated tag) 则 是 一 种 Git 物件 ， 
就 像 我 们 在 【第 06 天 : 解析 Git 资料 结构 - 物件 结 
构 】 提 到 的 ，Git 物件 包含 4 种 物件 类 型 ， 分 别 是 
Blob, Tree, Commit 与 Tag 物件 ， 这 壬 讲 的 上 标示 
票 敏 ， 就 是 Tag 物件 。Tag 物件 会 储存 在 Git 的 物 
件 储 存 区 当中 ( 会 存 到 .sit\objects\ 目 儿 下 ) ， 
范 且 会 关联 到 另 一 个 commit 物件 ， 建 立 “标示 栋 
毓 ， 时 还 能 像 建 立 commit 物件 时 一 样 包 含 “版 本 
讯息 。 在 内 建 的 Git 标 毓 机 制 中 ， 甚 至 你 还 可 以 
利用 GnuPG 金 欠 对 Tag 物件 加 以 签 章 ， 以 确保 讯 
息 的 “不 可 否认 性 ， 。 


只 然 我 们 有 和 这 两 种 标 短 类型， 看 起 来 也 都 像 某 个 
commit 物件 的 “别名 ， ， 但 这 两 种 标 敏 在 使 用 上 只 
有 些微 的 差 虹 而 已 。 在 大 部 分 的 使 用 情境 下 ， 我 们 
都 会 用 “标示 标 敏 ,来 建立 " 标 敏 物件 ， 殉 且 给 予 
版 本 讯息 ， 因 为 这 种 ' 标 敏 ， 才 是 Git 储存 库 


中 “永久 的 物件 , 。( 储存 到 物件 储存 库 中 的 Git 物 
件 都 是 不 释 的 ， 只 有 索引 才 是 变动 的 ) 


了 解 轻 量 标 笋 (lightweight tag) 的 使 用 
方式 


我 用 一 个 简单 的 例子 说 明 建 立 " 轻 量 标 敏 ， 的 过 
程 ， 如 下 图 示 : (请 自行 看 图 说 故事 ) 


: Ngit 一 hranch 一 CE -9itNhefsN\tags 
是 TEMPORhRRY 
8968 -6999 


G:Ngit-branch-demoN\.9it\efs\tags 的 目 儿 


Pa13xv1B@x1i4 上 年 19:39 《DIR> 
Pa13x16x1i4 上 于 19:39 《DIR> 


19?71hbz?zh 
ET 
on Oct 14 15:093:58 20913 +0800 


hbranch-demo >gqit tag 
hbranch-demo>gqit tag 1 工 -0.0-alpha 


:NgIiL 站 汪汪 下 -gitNrefsN\tags 
结 让 是 TEMPORRRY 
区 序 肪 : 99n926999 


It-hbranch-dqemoN\-9itNhefs\tags 的 目 铬 


Pal3v1evli4 上午 19:39 《DIR> 
Pal13v1evli4 上午 19:39 <《DIR> 
Pa1#vtiev15 上午 11:57 

由 档案 

个 目 天 


9it-hbranch-demo>type -9qit\refsN\tagqsN -0.0-alpha 
efalegca28hbhduca60237dq6858902hbl971hb7hbe35ac 


提示 : 所 有 在 .sit\refs\ 下 的 档案 都 是 个 “参考 
名 称 ， o 


大 致 的 使 用 说 明 如 下 : 


多 出 所 有 标 短 ,9it 七 ad 
建立 轻 量 标 示 束 鳃 : 9it tadg [tagname ] 


。 删除 轻 量 标 繁 : g9it tad [tagname] -Q 


如 果 我 们 想 看 这 个 轻 量 标 敏 ， 的 内 容 ， 我 们 可 以 
透 过 sit cat-file -pb [tagname] 取得 。 如 果 我 
们 想 看 这 个 轻 量 标 毓 ,的 物件 类 型 ， 可 以 透 

过 it cat-file - [tagname] 取得 。 如 下 转 
小 ， 


画 命令 提示 字 元 


:Ngit-hbranch-demo>git cat-file -bp .0.0-alpha 
Fee aee3763d6944e7hb2813e9996d5fgcac4l4a71hbg5 
iparent 38dq924fb9823993f941f78172hbad618641863c39 
uthor Will 《<doggvy-huangegmail.com> 1381734238 +0800 
ommitter WUil1l 《doggv-.huangegmail.com> 13817?734238 +0800 


BeSt 


:Ngit-branch-demo>git cat-file -~ 上 1 .0.09-alpha 
ommit 


请 注意 : 轻 量 标 毓 不 是 个 Git 物件 ， 所 以 我 们 从 上 力 
可 以 看 出 ， 该 Tag 名 称 取得 的 是 commit 物件 的 内 
容 ， 而 且 该 名 称 所 得 出 的 物件 类 型 是 commit 物 
作 : 


了 解 标 示 标 答 (annotated tag) 的 使 用 方 
式 


我 也 用 一 个 简单 的 例子 说 明 建 立 " 标示 标 毓 , 的 过 
程 ， 如 下 图 示 : (请 自行 看 图 说 故事 ) 


:Ngit-hbranch-demo>git 1og 于 

omnmii 8hbduca609232?7du68589092hbh19?1hb?hbe3 
Gogmail-com> 

14 15:093:58 2013 +0809 


{ < 
1 Le 已 


Fanch-dqemo >gqit tag 
pha 


ranch-qemo>git tag 工 -9-0-hbeta -aa -m “Beta_ uersion” 


IBeta uveksion 


:Ngit-branch-demo>git cat-file -tt 工 .09.09-hbheta 
aag 


这 壬 跟 “' 轻 量 标 敏 ， 有 些 不 一 样 的 地 方 : 


1. 当 我 们 执行 sit tag 列 出 所 有 标 敏 时， 所 有 标 
敏 都 会 混在 一 起 ， 看 不 出 标 毓 的 类 型 。 

2. 建立 “标示 标 敏 ， 要 加 上 -a 参数 。 

3. 建立 上“ 标示 标 毓 ， 一 定 要 加 上 版 本 讯息 ， ， 
跟 执 行 sit_ commit 一样 都 有 -m 参数 可 用 。 

4. 沼 我 们 执行 git cat-file -p 1.0.0-beta 
时 ， 你 应 该 可 以 看 出 这 个 物件 内 容 跟 commit 
物件 稍稍 有 点 不 同 。 


5. 贸 我 们 者 行 9it cat-file -P 1.0.0-beta 


时 ， 你 从 内 容 看 到 的 type 讲 的 是 上 一 
行 object 的 物件 类 型 ， 这 代表 你 也 可 以 把 任 
何 Git 物件 建立 成 一 个 标 毓 物 件 。 

6. 当 我 们 执行 git cat-file -t 1.0.0-beta 
时 ， 得 到 的 是 tag 物件 类 型 。 


标示 标 毓 的 指令 用 法 ， 跟 轻 量 标 敏 一 模 一 样 ， 差 别 
-a 参数 而 已 。 (如 果 只 有 使 用 -m 他 会 隐 含 
-a 也 贸 你 加 上 。 ) 


当前 的 HEaAp 
版 本 建立 成 “ 标 毓 物件 ，， 如 果 要 将 其 他 特定 物件 
建立 为 标 敏 的 用 法 


为 dit tad9 [tagname]l [object_ idl]。 


※ 害 设 9it tag [tagname] -a 会 将 
西 


今 今日 小 颖 


最 后 ， 我 把 本 篇 文章 建立 的 两 个 例子 重新 比较 一 
遍 ， 和 从 下 圆 你 应 该 可 以 很 清楚 看 出 两 者 之 间 的 差 
轴 : 


:Ngit-hbranch-demo>git tag 
-日 .9-alpha 
-日 .@-beta 


:Ngit-hbranch-demo >git Feu-pakrse 1.09.0-alpha 
efalegca28hduca6g8237d6858992hbhl1971b7?7hbhe35ac 


:Ngit-hbranch-demo >git Feu-parse 1.9.0-hbeta 
Htedlililihbh4e797a8184ed7hbh9cdq246q6afgBc87cae6 


:Ngit-hbranch-demo>git cat-file -tt efal 
ommit 


:Ngit-branch-demo>git cat-file -t 1ted 
ag 


:Ngit-branch-demo>git cat-file -p efal 


Fee aee3763d9944e7hb2813e9909d5fgcac414a71bg5 
1 

uthor Will 《 gmail.-com> 1381?734238 +D0800 
ommittekr Will 《 egmail-com> 1381?734238 +0809 


eSt 


:Ngit-hbranch-demo>git cat-file -p ited 

0Dhbject efalegca28hbdqca6B823?dq68589892hb19?1hb7hbhe35ac 

ype commit 

ag 工 - 昌 .08-hbeta 

aggekr 则 il1 《 egmail.com> 1381811229 +0868 


|Beta version 


:Ngit-branch-demo>git 1g9 
Tegc 2813-1B-14 《HENh 了 
1 2913-19-14 己 -txXt: S 
20 2913-19-14 Initial commit 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。 glit tag 
。git tag [tagname|] 
。git tag [tagname] -a 


git tag [tagname] -d 


若 想 查询 sit tag 的 完整 用 法 ， 可 在 命令 提示 字 
元 下 执行 git help tag 即 可 显示 完 王八 人 和 
明 。 


参考 种 结 


。 BRANCHING AND MERGING 
。 Semantic Versioning 


。 上 HOME 
。 回 目 色 
。 前 一 天 : Git for Windows 遗 项 设 定 


。 下 一 天 : 善 用 版 本 日 读 git reflog 追 跳 变 更 轨 中 


第 16 天 : 善 用 版 本 日 访 git 
reflog 追 跳 变 更 轨 踊 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/16.md 


和 Git 版 本 控 管 的 指令 操作 净 不 订 ， 但 要 弄 
清楚 G 二 膛 真 不 大 
人 当 你 一 步 了 解 Git 的 核心 与 运作 原理 ， 自 

能 有 效 学 控 Git 储存 庆 中 的 版 本 释 化 。 本 篇 文 
章 ， 就 来 说 说 Git 如 何 记 针 我 们 的 每 一 版 的 释 更 轨 
蚊 。 


了 解 版 本 纪 公 的 过 程 


在 清楚 理解 Git 基础 原理 与 物件 结构 之 前 ， 你 不 

能 了 解 版 本 纪 针 的 过 程 。 es 
过 程 ， 自 然 会 担心 “到底 我 的 版 本 到 哪 去 了 ，， 也 
许 有 人 跟 你 说 “我 们 用 了 版 本 控 管 ， 所 以 所 有 版 本 
都 会 留 下 ， 你 大 可 放心 改 Code , 。 知 道 是 一 回 
事 ， 知 不 知道 拒 床 做 又 是 一 回 事 ， 然 后 是 不 是 真 的 


做 得 到 又 是 另外 一 回 事 。 我 们 在 版 控 的 过 程 中 画 情 
commit 建立 版 本 ， 但 如 果 有 一 天 发 现 有 有 某 个 版 本 改 
坏 了 ， 或 是 因为 执行 了 一 些 合 侍 或 重 置 等 动作 导致 
版 本 消失 了 ， 那 又 该 怎 厌 办 呢 ? 


还 好 在 Git 里 面 ， 有 一 套 有 讶 的 纪 凶 机 制 ， 而 且 这 
套 机 制 非 常 开 放 ， 纪 他 的 档案 都 是 文字 格式 ， 还 继 
容易 了 解 ， 接 下 来 我 们 就 来 说 明 版 本 纪 他 的 过 程 。 


我 们 先进 入 任何 一 个 Git 工作 目 销 的 .sity/ 资料 
夹 ， 你 可 以 看 到 一 个 ods 目 色 如 下 图 示 : 


豆 胶 ，》 TEMPORARY (G3] ，》 git-branch-demo ，》.9it 》 
^ 名 帮 修改 日 期 


山 hooks 2013/10/14 上 午 
2013/10/14 上 午 


2013/10/14 上 午 .… 


建立 目 期 : 2013/10/ 二 上 午 1039 二 
大 小 : 924 个 位 元 给 机 
包 COMMIT_ EDITMSG | 资料 六 : refs 


全 config 模 宗 : HEAD 本 
全 description 2013/10/14 上 午 .. 
岛 HEAD 2013/10/14 上 二 
全 index 2013/10/15 上 二 - 
仿 ORIG_HEAD 2013/10/14 下午 
仿 TAG_EDITMSG 2013/10/15 下 千 _. 


这 个 logs 资料 来 下 有 个 azap 档案 ， 这 档案 纪 针 
著 “ 当前 分 支 : 的 版 本 释 更 纪 销 : 


豆 脑 ， TEMPORARY (G:) ， git-branch-demo 上 .gt ， logs 


大 


^ ”名 稀 候 蕊 
凯 refs 2013/10714 
仿 HEAD 2013/10/115 


我 们 开 欣 该 档 看 看 其 内 容 (其 中 物件 id 的 部 分 我 有 
刻意 稍 作 删 沽 ， 以 免 每 行 的 内 容 过 长 ) : 


0000000 f5685e0 Wil1l 
f5685e0 38q924f Wil1l 
38d924f efale0c 人 IILL 
efale0c af493e5 WiL1lL1 


<XXXXQdgmalILI 


<XXXXQdgmalil. 


<XXXXQdgmaiI1I 


<XXXXQdgmali1I 


晤 @eille 


Com 芝 


请 eeitl 芭 : 


CGI 这 


1381718394 
84 路 18395 
1381134238 
SeBp37967 


从 这 壬 你 将 可 看 出 目前 在 这 个 分 支 下 曾经 记 销 过 4 
个 版 本 ， 此 时 我 伯 用 it esloe 即 可 列 印 出 所 有 
历史 纪 公 ， 的 版 本 释 化 ， 你 会 发 现 内 容 是 一 


的 ， 但 | 


一 版 , 在 最 上 面 ， 国 


显示 最 新 版 , 最 后 


CNWindowsNsystem32Xcmd.exe 


:Ngit-hbranch-demo>gqit Fef1log 
HEhNDB<B>: commit: hddqd c -txt 


HEhDB<《1>: commit: test 
HEhDB<2>: commit: a-txt: Set 1 as content 
HEhDB《3y>: commit 《initial>: 


第 一 版 ， 


Initial commit 


dit reflod 


自序 正好 血 倒 。 和 从 文子 档 中 看 到 的 内 容 ， 
则 是 先 


这 时 我 们 试图 建立 一 个 新 版 本 ， 看 看 记 他 档 的 释 
化 ， 你 会 发 现 版 本 被 建立 成 功 : 


CNWindows\system32NXcmd.exe 


:Ngit-hbranch-demo >echo QQ > dtxt 
:Ngit-branch-demo>git add  - 


:Ngit-hbranch-demo>git commit -nm “hadd Qtxt” 
[master 9967hb3f] hadqq Qtxt 

荆 于 ile changed。 1 insertionC+7> 

chFeate mode 199644 Qtxt 


:Ngit-hbranch-demo>git Fef1log 
HEhRDB<By> : commit: hdq Qtxt 
HEhRDB<1L>: commit: hddqd c -txt 
HEhRDB<《2>: commit: test 
HEhDB<3>: commit: a-txt: Set 1 as content 


HEhDB《4>: commit 《initial>: Initial commit 


从 上 图 你 可 以 发 现 到 ， 这 里 有 个 特殊 的 “ 参考 名 
称 , 为 HEApet0}， 这 守 每 个 版 本 都 会 有 一 个 历史 
纪 针 都 会 有 个 编号 ， 代 表 著 这 个 版 本 的 在 记 人 录 档 中 
的 顺 位 。 如 果 是 Eapetol 的 话 ， 永 下 代表 目前 分 
支 的 “最 新 版 , ， 换 句 话说 就 是 你 在 这 个 “分 支 ， 
中 最 近 一 次 对 Git 操作 的 纪 公 。 你 对 Git 所 做 的 任 
何 版 本 释 更， 全 部 都 会 被 记 休 下 来 。 


复原 意外 地 释 


初学 者 刚 开 始 使 用 Git 很 有 可 能 会 不 小 心 执行 错 
误 ， 例 如 透 过 sit merge 执行 合 供 时 发 生 了 种 突 ， 
或 是 透 过 sit pul1l 取得 这 端 储存 库 最 新 版 时 发 生 


了 失误 。 在 这 种 情况 下 ， 你 可 以 利用 azapet0l 这 
个 特殊 的 “参考 名 称 , 来 对 此 版 本 ' 定位 ， 芷 将 
目前 的 Git 储存 库 版 本 回复 到 前 一 版 或 前 面 好 几 
版 。 


例如 ， 我 们 如 果 想 要 ' 取消 , 最 近 一 次 的 版 本 纪 

杀 ， 我 们 可 以 透 过 it reset HEADeG{1} --harqa 
来 复原 变更 。 如 此 一 来 ， 这 个 原本 在 HEapetol 的 
变更 ， 就 会 被 删除 。 不 过 ， 在 Git 里 面 ， 所 有 的 释 
更 都 会 被 记 杀 ， 其 中 包含 你 

做 sit reset "HEADeltlj" --hard 的 这 个 动作 ， 
如 下 图 示 : 


CNWindows\system32Xcmd.exe 


:Ngit-hbranch-demo>git 1 

?96?7hb3f 2913-19-15 上 hddq QQ.txt 《HEhD。masteFr> [ ] 
af493e5 2013-19-15 }) haddq c-txt 《origin/masterkr。testhbranchy》 
efalegc 2013-109-14 上 test tag: 1.0.0-hbheta。tag: 1.0.0-alph 
38d924f 2013-10-14 上 a-txt: Set 1 as content [ ] 

f5685eg 20913-169-14 ! Initial commit [ ] 


:Ngit-hbranch-demo>gqit Fef1log 
?367hb3f HEhRDB<O7> : commit: hdd Qtxt 
Je5 HEhNDG<L>: commit: hdqdqd c -txt 
HEhDG《2>: commit: test 
HEhNDB<《3>: commit: a-txt: Set 1 as content 
HEhDB<4>: commit 《initial>: Initial commit 


:Ngit-branch-demo>git keset "HEhNDGX1L>”” 一-hard 
EhD is now at af493e5 hdd c -txt 


:Ngit-hbranch-demo>git 1 

af493e5 20913-19-15 上 hddq c-txt 《HEhND。originAmaster。testhbhr 
efalegc 2013-109-14 上 test〈tag: 1.0.09-hbheta。tag: 1.0.0-alph 
38d924f 2013-10-14 ! a-txt: set 1 as content [ ] 

f5685eg 20913-19-14 ! Initial commit [ 是 


:Ngit-hbranch-demo>git Fef1log 
< 5 HERDB<BOY> : keset: mouing to HEhRDGK<Ty> 
江 HEhRDB<1L>: commit: hddq Qtxt 
5 HEhDBe《2y>: commit: hdqdq c -txt 
HEhRDG<3>: commit: test 
fF HEhDB<4>: commit: a-txt: Set 1 as content 
JeD HEhRDGX5>: commit 《initial>: Initial commit 


这 代表 甚 育 意 义 呢 ? 这 代表 你 在 执行 任意 Git 命令 
时 ， 再 也 不 用 担心 害怕 你 的 任何 资料 会 遗失 ， 就 算 
你 怎 檬 下 错 指令 都 没 关 傈 ， 所 有 已 经 在 版 本 库 中 的 
档案 ， 全 部 都 会 保存 下 来 ， 完 全 不 会 有 遗失 的 机 
会 。 所 以 ， 这 时 如 果 你 想 复 原 刚 刚 执 行 

的 sit reset "HEADef1lj" --hard 动作 ， 只 要 再 
执行 一 次 git reset "HEADa{1}" --hard 即 可 ， 
是 不 是 非 营 棒 呢 ! 你 看 下 图， 我 把 刚刚 的 9967b3f 
这 版 本 给 救 回来 了 : 


CNWindows\system32Xcmd.exe 


:Ngit-hbranch-demo>git 11 

af493e5 2013-19-15 ! hddq c-txt 《HEhND。originmasteF。testhhr 
efalegc 2013-109-14 上 test 《tag: 1.0.0-beta。tag: 1-.09.9-alph 
38dqd924f 2913-16-14 ! a-txt: Set 1 as content [ ] 

f5685eg 20913-19-14 ; Initial commit [ ] 


:Ngit-branch-demo>git Fef1log 
423e5 HEhDB《XO>: keset: mouing to HEhRDGKXTLy> 
?9?67pb3f HEhRDB<1>: commit: hddq Qtxt 
HENDG<2>: commit: hddq c -txt 
HEhDGK《3y>: commit: 上 test 
二 HEhRDB<4>: commit: a-txt: Set 1 as content 
9 HEhRDB<5y>: commit 《initial>: Initial commit 


:Ngit-hbranch-demo>git Feset "HEhNDGBX1>” 一 -hard 
EhD is now at 9967hb3f hddq Qtxt 


hbranch-demo>git ef1log 
洁 HERDBXO7> : Feset: mouing to HEhNDG《Ty> 
HENRDG<1L> : Feset: mouling to HEhNDBGKXAIT> 
江 HEhRDB<《2>: commit: hdqd Qtxt 
)， HERDB<3>: commit: hdd c -txt 
HEhDB<《4>: commit: test 


HEhRDB《5》>: commit: a-txt: Set 1 as content 
D HEhRDBG《6y>: commit 《initial>: Initial commit 


:Ngit-hbranch-demo>git 11 

9396?7hb3f 2013-19-15 上 haddq Qtxt 《HEhD。 master> [ ] 
af493e5 2013-19-15 ; hdd c-txt 《okFigin/master。testhbranchy> 
efalegc 20913-109-14 上 test 《tag: 1.0.09-hbheta。tag: 1.0.0-alph 
38d924f 2013-10-14 ! a-txt: set 1 as content [ ] 

f5685eg 2913-19-14 ! Initial commit [ ] 


纪 公 版 本 释 更 的 原则 


事实 上 在 使 用 Git 版 控 的 过 程 中 ， 有 很 多 机 会 会 彦 
生 版 本 厅 史 纪 人 ,，， 我 说 的 普 不 是 哩 多 

的 GIit 显示 版 本 纪 外 ， 而 是 原始 且 完 整 的 变 
压 史 纪 休 。 这 些 纪 休 版 本 释 更 有 个 基本 原则 : 【只 
要 你 透 过 指令 ee 或 是 变 
更 任何 分 支 的 HEap 参照 内 容 ， 就 会 建立 历史 纪 
凶 】。 也 因 往 这 个 原则 , 所 以 指令 名 称 才 会 称 


为 reflog ,因为 是 鸣 了 ref ( 参 照 内 容 ) 才 引 发 
的 | ( 纪 色 )。 


例如 我 们 拿 9it checkout 命令 还 切换 不 同 的 分 
支 ， 这 个 切换 的 过 程 由 於 会 修改 .sit\HEap 参照 的 
内 容 ， 所 以 也 会 凑 生 一 个 奈 史 纪 杀 ， 如 下 图 示 : 


CNWindowsvsystem32Ncmd.exe 


:Ngit-hbranch-demo>gqit co testhbranch 
朴 witched to branch “testhbFranch” 


:Ngit-hbranch-demo>git Fef1log 
HEhRDG《By> : checkout: mouing fkrom mastek to testhbranch 
HEhRDG《1L》>: Feset: mouing to HERDGXTy> 


HEhRDB<2>: Feset: mouing to HEhNDBG<Ty> 
HEhDG《37y>: commit: hddqd dtxt 

HEhRDB<47>: commit: hdqqd c -txt 

HEhRDGX5》>: commit: test 

HEhRDG《6y>: commit: a-txt: Set 1 as content 
HEhDB<《?7>: commit 《initial2>: Initial commit 


还 有 哪些 动作 会 导致 产生 新 的 reflog 纪 凶 呢 ? 以 下 
做 个 动作 你 可 以 参考 ， 但 其 实 可 以 不 用 死记 ， 记 住 
原则 融 好 了 : 


。 Commit 
。 Checkout 
。 pull 

。 push 

。 merge 

。 eset 

。 clone 


。 branch 
。 rebase 
。 Stash 


除 此 之 外 ， 每 一 个 分 支 、 每 一 个 暂 存 版 本 (stash) ， 
都 会 有 自己 的 reflog 历史 纪 杀 ， 这 些 资料 也 全 都 会 
储存 在 .git\logs\refs\ 资料 灾 下 。 


只 显示 特定 分 支 的 reflog 纪 针 


在 查询 历史 纪 杀 时 ， 你 也 可 以 针对 特定 分 支 
(Branch) 进 行 查 询 ， 俊 显示 特定 分 支 的 弧 更 历史 纪 
外 ， 如 下 力 示 : 


到 CNWindows\system32Ncmd.exe 


:Ngit-hbranch-demo>git branch 
masSteh 


te 


:Ngit-branch-demo>git Fef1log HEhD 
HEhRDG<B> : checkout: mouing fkrom mastekr to testhbranch 
fF HEhNDe<1L>: keset: mouing to HEhNDGK<TL> 
5 HEhDBGX《2y>: keset: mouing to HEhRDBGX《TL7 
HEhRDG<《37>: commit: hdqd Qtxt 
HEhRDG<4>: commit: hdqdq c -txt 
HEhNDGX《5》>: commit: 上 test 
HEhDG<《6y>: commit: a-txt: Set 1 as content 
) HEhRDB<《7>: commit 《initial2: Initial commit 


:Ngit-hbranch-demo>git Fef1log mastek 
F masterekgy: Feset: mouling to HEhDGXTL7> 
) masterek1>: Feset: mouing to HENDGX《Iy> 
mastere《27>: commit: hdd qd .txt 


mastekhe《37y>: commit: hddq c .txt 
masteredk47y: commit : test 
mastekrek《5y: commit: a-txt: Set 1 as content 
mastere《6y: commit 《initial>: Initial commit 


:Ngit-hbranch-demo>git Feflog testhbranch 
5 上 esthbranche《g9y : branch: Created fkom mastek 


显示 reflog 的 详细 版 本 记 色 


我 们 已 经 学 会 用 sit reflog 就 可 以 取出 版 本 雁 史 
机 但 如 果 我 们 想 要 显示 每 一 个 
reflog 版 本 中 ， 每 一 个 版 本 的 完整 commit 内 容 ， 那 
矿 你 可 以 用 sit 1log -9 指令 显示 出 来 : 


[] CNWindows\system32Xcmd.exe - git log -9 


:Ngit-hbranch-demo>git 1og -9 
commit af493e54h4a2f5hb31ahbh9f9 ca3393c38 
gmail.-com>> 
: checkout: mouving from mastekr to testhbranch 
: Wi1lL1《 Bgmail.-com> 
Tue Oct 15 19:52:47 2013 +0800 


haddq c -txt 


?hb3f68eb6D9hl 2y4b 124f3dhbhc>765c2f3f8 
gmail.com>> 
: FesSet: mouing to HEhRDGXTL> 
: Will 《 Bgmail.com> 
Tue Oct 15 209:26:33 2013 +0809 


hadd .txt 


m af493e54h4a2f5b31ahb9f91: 2?7c?7a3393c38 
ef]1og: HEhDGE2> 《WilL1L 《 gmail-com>> 


ef 1og message: FeSet: mouing to HEhNDGXTLy> 
: Will 《 gmail.-comy> 
Tue Oct 15 19:52:47 2913 +0869 


hadqq c -txt 


7hb3f68e699hbhb12296hbegl24f3dhbc?65c2f3f8 
: HEhRDB437> 《内 IIL1 < Bgmail.-com>> 
: commit: haddq Qtxt 
"5 则 1L1 《 gmail.com> 
Tue Oct 15 29:26:33 2013 +0800 


hadqq Qtxt 


93e54hbh4a2f5hb31ahb9f91 27ycya3303c38 
: HEhRDBG<《4> 《WilL1 《 gmail.com>》> 
ef1og message: commit: hdd c -txt 
3 风 iLLL《 Bgmail1.com> 
Tue Oct 15 19:52:47 2013 +0800 


删除 特定 给 个 版 本 的 奈 史 纪 甸 


基本 上 ， 版 本 日 读 (reflog) 所 记 销 的 只 是 变更 的 殿 

程 ， 而 且 预 设 只 会 储存 在 "工作 目 朱 ,， 下 的 .sit/ 
目 色 壬 ， 过 壬 所 记 公 的 一 样 只 是 commit 物件 的 指 
标 而 已 。 扰 论 你 对 这 些 纪 针 做 任何 操作 ， 不 管 是 


有 删除 ， 都 不 会 影响 到 目前 物件 储存 库 的 任何 内 
, 也 不 会 影响 版 本 控 管 的 任何 资讯 。 


如 果 你 想 删 除 之 前 纪 杀 的 某 些 纪 人 外 ， 可 以 利 
用 9it reflod qdqelete refQ{fspecifierl} 来 删除 


特定 历史 纪 公 。 如 下 图 示 : 


[| CNWindows\system32N\cmd.exe 


:Ngit-hbranch-demo>git Fef1log 

HEhDB<《B9y> : checkout: mouing fkom mastek to testhbhranch 
HEhDBX1L>: Feset: mouing to HEhNDG《Ty> 
HEhDGX2y>: Feset: mouing to HEhNDGXTy> 
HEhDB<《3>: commit: hdqdqd Qtxt 

)， HERDB<4>: commit: haddq c -txt 
HEhDG<《5>: commit: test 
HEhRDG<《6>: commit: a-txt: Set 1 as content 

) HEhRDG<《7>: commit 〈《initial>: Initial commit 


:Ngit-hbranch-demo>git Feflog delete HEhRDG<By> 


:Ngit-hbranch-demo>git Fef1log 

| HEhNDG<《By> : Feset: mouing to HENDGXTy> 
HEhDBGX1L》>: Feset: mouing to HEhNDG《XTy> 
HEhDG<《2>: commit: hddqd Qtxt 
HEhDB<《3>: commit: hdqd c -txt 
HEhRDB<4>: commit: test 
HEhDB<5>: commit: a-txt: Set 1 as content 

eD HEhRDB《6y>: commit 《initial>: Initial commit 


:Ngit-branch-demo>git Feflog delete HEhDGXBOy> 


:Ngit-hbranch-demo>git Feflog delete HEhRDG<By> 


:Ngit-hbranch-demo>git ef1log 

e5 HEhDBe《By>: commit: hadqddq Qtxt 
HEhRDG<《1L>: commit: hdqd c -txt 
HEhDB<《2>: commit: test 


HEhRDB《3>: commit: a-txt: Set 1 as content 
) HEhRDG<4>: commit 《initial>: Initial commit 


:Ng9it-hbranch-qemo> 


版 本 日 读 预 设 冰 不 会 被 同步 到 ' 踪 端 储存 
库 ，， ， 以免 多 人 开 酿 转 大 家 互相 影响 ， 所 以 版 本 日 


了 川上 
HH 
定 
| 长 


读 算 是 比较 个 人 的 东西 。 


设 定 压 史 纪 凶 的 过 期 时 间 


当 你 的 Git 储存 库 越 用 越久 ， 可 想见 这 份 历史 纪 针 
ee , 这 样 难 道 不 会 爆 掉 吗 ? 还 好 ， 预 

说 Git 会 攻 你 保存 这 些 历 史 纪 儿 90 天 ， 如 果 过 
些 各 生 中 已 经 有 些 commit 物件 不 在 分 支线 上 ， 则 
预 设 会 保留 30 天 。 


区 


浴 个 例子 来 说 ， 假 如 你 先前 建立 了 一 个 分 支 ， 然 后 
commit 了 类 个 版 本 ， 最 和 后 直接 把 该 分 支 删 掉 ， 这 时 
这 些 曾 经 commit 过 的 版 本 ( 即 commit 物件 ) 还 会 

储存 在 物件 储存 区 (object storage) 中 ， 但 已 经 无 法 
使 用 sit 1log 取得 该 版 本 ， 我 们 会 称 这 些 版 本 为 

7 不 在 分 支线 上 的 版 本 ， 。 


如 果 你 想 修 改 预 设 的 过 期 期 限 ， 可 以 透 
过 dgit config gc.reflogExPire 


时 9it confid 9g9c.reflogqExpireUnreachable 来 
修正 这 两 个 过 期 预 设 值 。 如 果 你 的 硬 碟 很 大 ， 了 永 踪 
不 想 删 除 纪 外 ， 可 以 考虑 设 定 如 下 : 


Geaeleinae 辣 二 二 GEGoEEEOG 和 汪 本 ee 人 LSNSE 


9it config --g9lobal gc.ref1lLlogExpPpireUnreachable " 


如 果 只 想 保存 7 天 ， 则 可 考 厌 设 定 如 下 : 


GEECCnETO Eliocal agegEPee OOayS" 
CEEcontTo localoce reflicoaoBxzPpreUnreeacneble 


主 : 从 上 述 和 范例 所 看 到 的 7 aays 这 段 字 ， 我 找 了 
好 广 都 ; 包 有 看 到 完整 的 说 明文 件 ， 最 和 后 终 於 找到 Git 
上 处理 日 期 格式 的 原始 码 (C 语 言 ) ,有 奥 趣 的 也 可 以 看 
看 : http:/git.kernel.org/cgitgitgit.gittree/date.c 


除 此 之 外 ， 你 也 可 以 针 针 特定 分 支 设 定 其 预 设 的 过 
期 时 间 。 例 如 我 想 议 master 分 支 只 保留 14 天 期 ， 
而 develop 分 支 可 以 保留 完整 记 从 “， 那 床 你 可 以 这 
样 设 定 : (注意 : 以 下 范例 我 把 设 定 储存 在 本 地 储存 
库 中 ， 所 以 使 用 了 --1local 参数 ) 


GeoOnmng 王 三 OCS oemalSHESET SEOgE 广 Dos 14 Qa 


ERconfoeToea oemastEeRelioogExoareuUhreach 


dit config --1LIocal gc.aqevelLlop.reflogExpPirel "nevVe 


9it config --1LIocal gc.dqevelLlop.reflogExpireUnreac 


上 述 指令 写 入 到 .sit\config 的 内 容 将 会 是 : 


EeemYmssiesmse 诈 


reflogExpire = 14 qays 


reflogExpPpireUnreachable = 14 qays 
Eeeasveem 划 


zeflogExpPire = mevVeL 


reflogExpPpireUnteachable = meVeL 


靖 除 奈 史 纪录 
若 要 立即 清除 所 有 历史 纪录 ， 可 以 使 


用 9it reflod expire eXDP1Ire=now --all 指令 
完成 删除 工作 ， 最 人 后 搭配 sit sc 重新 整理 或 清除 
那些 找 不 到 、 撼 法 追 跳 的 版 本 。 如 下 图 示 : 


目 


CNWindows\system32Ncmd.exe 


:Ngit-hbranch-demo >git Fef1log 
HEhDG《B9y> : checkout: mouing from masteFr to testhbhranch 
HEhDG《1L》>: Feset: mouing to HEhNDGXTy> 
HEhRDG<2>: Feset: mouing to HEhRDBGKXTy> 
HEhRDG<37>: commit: haqq Qtxt 
HEhRDB<4>: commit: hdqd c -txt 
HEhRDGX5》>: commit: test 
HEhRDG《6y>: commit: a-txt: Set 1 as content 
HEhRDB<《7>: commit 《initial>: Initial commit 


:Ngit-hbranch-demo>git Fef1log expiFre --expire=now --al1 


:Ngit-hbranch-demo>git gc 
ounting ohbjects: 15。done - 
pelta compkession using up to 8 threads - 
ompkessing ohbjects: 1009x 《9-9?9>。done - 
JPiting ohbjects: 109x 《15/15>。done - 
otal 15 《delta 2?。heused 9 《delta D) 


:Ngit-hbranch-demo>git ef1log 


:Ngit-hbranch-qemo >。 


今日 小 结 


Git 的 版 本 日 读 (reflog) 姓 我 们 记 居 在 版 控 过 程 中 的 
所 有 释 更 ， 攻 助 我 们 ' 回 居 ， 到 底 这 段 时 间 到 底 革 
Git 储存 库 做 了 什 记 不 过 你 也 要 很 清楚 的 知道 

这 些 只 是 个 ' 日 读 , 而 已 ， 不 管 有 没有 这 些 日 读 ， 
都 不 影响 我 们 Git 储存 库 中 的 任何 版 本 资讯 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git reflog 

。git reflog [ref 

。gitlog -g 

git reset "HEADQ@{1}”--hard 


git reflog delete "ref@@{specifiem” 

。git reflog delete "HEADG@{0}” 

git reflog expire --expire=now --all 

。git gc 

git config --global gc.reflogExpire "never 


。git config --global gc.reflogExpireUnreachable 


"never 
本 人 
参考 建 颖 


。git-reflog(1) Manual Page 
。git-gc(1) Manual Page 
。 http:Vgit.kernel.org/cgit/gitgit.gittree/date.c 


第 17 大 : 关於 合 供 的 基本 现 
念 与 使 用 方式 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/17.md 


我 曾 在 【第 08 天 : 关於 分 支 的 基本 观念 与 使 用 方 
式 】 提 过 关於 " 分支, 的 基本 观念 与 用 法 ， 现 在 则 
要 来 讲 ' 合 们 ， 如何 进 行 。 由 於 Git 是 一 种 分 散 式 
版 本 控 管 系统 (DVCS)， 过 程 中 会 不 断 的 进行 分 支 与 
合 侍 ， 扰 论 是 有 意 的 合 供 (sit merge) 或 德 意 的 合 侍 
(sit pull)， 总 之 使 用 Git 版 控 "分支 与 ' 合 
儒 : 的 动作 确实 经 常 发 生 。 本 篇 文章 将 说 明 ' 合 
儒 , 动作 的 基本 必 念 与 使 用 方式 。 


关於 “ 合 侍 ， 的 基本 盯 念 


当 你 在 Git 工作 目 销 下 建立 分 支 时 ， 可 以 让 你 的 系 
统 依据 不 同 的 需求 分 别 进行 开发 ， 又 不 互相 影 唤 。 

例如 你 原本 称 定 的 系统 可 以 放 在 master 分 支 中 进 
行 开 发 ， 而 当 要 修正 错误 时 则 额外 建立 一 


个 busfix 分 支 来 改正 软体 错误 ， 等 Bugs 修正 
和 后， 在 透 过 ' 合 人 , 的 方式 将 bugfix 分 文 上 的 变 
更 重新 套用 到 master 上 面 ， 这 就 是 一 种 主要 的 使 


用 情境 。 


一 般 来 说 ， 大 家 都 是 以 一 个 主要 或 预 设 分 支 进行 开 


发 (naster) 7 然后 再 依据 需求 建立 分 支 (bugfizx) 5 最 
后 则 是 将 两 个 分 支 合 供 成 一 个 。 事 实 上 ， 执 行 " 合 
儒 , 动作 时 ， 是 将 另 一 个 分 支 合 儒 回 目前 分 支 ， 然 


后 再 手动 将 另 一 个 分 支 给 移 除 ， 过 样 才 符合 ' 两 个 
分 支 合 供 成 一 个 , 的 概念 。 


实务 上 ， 也 经 常 有 机 会 将 三 个 、 四 个 或 更 多 的 分 支 
合 人 到 其 中 一 个 分 支 。 例 如 你 除了 主要 分 支 
(master) 外 ， 还 额外 建立 了 除 销 用 的 分 支 (pusfix) 和 与 
新 增 功能 (feature) 的 分 支 ， 当 并 发 到 一 定 程 度 后 ， 
你 可 以 决定 要 不 要 将 这 个 两 个 分 支 一 起 合 供 回 主要 


分 支 (mnaster)。 


在 Git 使 用 合 供 时 ， 有 一 个 重要 的 观念 是 【 合 供 的 
动作 必须 发 生 在 同一 个 储存 库 中 】。 请 回想 一 下 ， 
在 任何 一 个 Git 储存 库 中 ， 都 必须 存在 一 个 Initial 
Commit 物件 (初始 版 本 )， 而 所 有 其 他 版 本 都 会 跟 这 
仙 版 本 有 关 休 ， 这 个 关 傈 我 们 称 为 “在 分 支线 上 的 


可 追 跳 物件 ， (the tracked object on the branch 
heads)， 所 以 你 不 能 将 一 个 储存 库 的 特定 分 支 合 供 
到 另 一 个 毫 不 相干 的 储存 库 的 某 个 分 支 里 。 


合 供 的 时 候 ， 如 果 两 个 分 支 当 中 有 修改 到 相同 的 档 
案 ， 但 只 要 修改 的 行 数 不 一 样 ，Git 就 会 自动 党 你 套 
用 / 合 供 这 两 个 变更 。 但 如 果 就 这 庆 刚 好 ， 你 在 两 个 
分 文 壬 面 改 到 上 同一 个 档案 , 的 :同一 行 ; ， 那 和 
在 合 供 的 时 候 就 会 引发 备 突 事件 。 当 合 供 衢 突 发 生 
时 ，Git 下 不 会 攻 你 决定 任何 事情 ， 而 是 将 ' 解决 衢 
突 , 的 工作 交 给 " 你, 来 负责 ， 且 这 些 发 生 衢 突 的 
档案 也 都 会 被 标示 为 unmergead 状态 ， 合 供 征 突 人 后 
你 可 以 用 sit status 指令 看 到 这 些 状 态 。 


体验 一 场 "成功 的 合 供 ， 


简单 来 说 ，“ 成 功 的 合 人 ， 就 是 没有 发 生 ' 种 突 ， 
的 合作 。 我 们 用 一 个 简单 的 例子 说 明 合 供 的 过 程 与 
指令 的 用 法 : 


mkdqir 9it-merge-dqemo 
cq dg9it-merde-dqemo 


ENal IE 


SO EU IE>CE 
GE 


避让 古 Ginin 生 在 三 二 放生 站 下 在 下 是 且 忆 全 站 用 下 不 OCEeseeEd)" 


IO EECIE 
GE SEOdI 


GCCOImE ET 本 本 区 ee 文臣 上 


执行 结果 如 下 图 示 ， 我 们 建立 了 两 人 向 版本， 而且 最 
新 版 的 a.txt 内 容 为 1 1: 


:Nmkdir git-mekrgqe-demo 
:N\?>cd 9it-mekrge-demo 


:Ngit-mekgqe-demo>git init 
Initialized empty Git kepositoFky in G:-9qit-mekge-demo~-git~ 


:Ngit-merkrge-dqemo> 
:Ngqit-merkrge-demo>echo- > a-txt 


It-meFrge-demo>git add  - 


:Ngqit-mekge-demo>git commit -m "Initial commit 〈《a-txt ckheated7>7 
[master 《Foot-commit》 aqdb?l2e] Initial commit 〈《a-txt cFeated7> 

1 file changed。 1 insektionCG+?> 

ceate mode 10909644 a-txt 


:Ngqit-mekge-demo> 
:Ngit-merkgqe-demo>echo 1 > aa-txt 


:Ngit-mergqe-demo>git add 

:Ngqit-mekge-demo>git commit -m "Update aa-txte 
[master e5c5gB8f] Update Ba-txtg 

1 file changed。 1 insePktionK+>。 1 deletionf(K 一 )> 

:Ngit-mekge-demo>git 1og 

8Sfg9hb2d91e1lBa63ede2hb3 

huthor : Will 《xxxegmail.comy> 

Date : Wed Oct 16 19:43:58 20913 +0860 


Upadqate 习 -txt9 


Commit adhb' e4ef: 


Uil1l 《xxxegmail-com> 
Wed Oct 16 19:43:53 20913 +0860 


Initial commit 〈《a-txt ckeated)? 


:Ngit-mekge-demo >type aa-txt 


:Ng9it-merge-demo > 


接著 我 们 透 过 9it checkout -b feature 建立 一 
个 feature 分 支 ， 革 同时 把 工作 目 人 录 给 切换 
到 feature 分 支 进行 开发 ， 然 后 建立 一 个 内 容 为 2 


的 b.txt 档案 


:Ngit-merkrgqe-demo>git branch 


:Ngit-merge-demo>git checkout -hb featue 
Switched to aa new branch “featuFe” 


:Ngit-merkrgqe-demo>git branch 

上 已 atUU 

masStek 

:Ngit-merge-demo>echo 2 > hb.txt 


:Ngit-merkrgqe-demo>type pb.-txt 


:Ng9it-meFkrgqe-demo>git add - 


:Ngit-merge-demo>git commit -m “用 Qqd hb txt” 
[featuke 99dc26e] haqd b.txt 

1 file changed。 1 insektioncC+》 

ckeate mode 1909644 b.txt 


:Ng9it-mekrge-demo>。 


注意 : 在 切换 " 分 支 」 之 前 ， 请 随时 查看 站 保 持 
工作 目 人 录 ,的 状态 是 乾 兆 的 , ， 不 要 有 任何 榴 
案 轴 动 中 的 状态 。 


现在 我 们 回顾 一 下 两 个 分 支 的 内 容 : 
。 主要 分 支 : master 


O 所有 a.txt 其 内 容 为 1 
。 功能 分 支 : feature (目前 所 在 分 支 ) 


O 瓜 有 a.txt 其 内 容 移 1 (此 档案 是 
和 从 master 分 支 继承 过 来 的 ) 
O 瓜 有 b.txt 其 内 容 为 2 


我 们 现在 要 做 3 件 事 


1. 将 工作 目 人 切换 回 master 主要 分 文 

2. 将 a.txt 的 内 容 新 增 一 行 NEW LINE 在 第 二 行 
(第 一 行 不 动 ) 

3. 将 a.txt 的 村 动 加 入 索引 ， 将 commit 版 本 


如 下 图 示 


:Ngit-mergqe-demo>git status 
惜 On branch featuFe 
othing to commit 。 woFking directoky clean 


:Ngit-mergqe-demo>git checkout master 
Switched to branch master 


:Ngit-merkrgqe-demo>echo NEW LINE >> aa-txt 
:Ngit-mergqe-demo>type aa-txt 


EU LINE 


:Ngit-mekgqe-demo>git status 
On branch master 
Changes not Staged for commit : 
use "git add 《file>---" to update what will be committed> 
《use "9git checkout --《file>---" to discard changes in working dd 


0 changes added to commit 《use "qit add'" andAor "qit commit 一 a")》 


:Ngit-mergqe-demo>git add - 


:Ngit-mekge-demo>git commit -~-m “Update a-txt: append NEWU LINE” 
[mastekr cd4728?7e] Updqate a-txt: append NEWU LINE 
1 file changed- 1 inseFtionC+7 


:Ngit-merkrge-demo > 


现在 我 们 再 回顾 一 次 久 下 两 个 分 支 的 内 容 : 
主要 分 支 : master (目前 所 在 分 支 ) 


所 有 a.txt 其 内 容 有 两 行 ， 第 一 行 


入 1, 第 二 行 是 NEW LINE 

〇 这 里 没有 feature 分 支 的 弧 更 ， 也 就 是 
没有 b.txt 档案 。 

。 功能 分 支 : feature 

〇 扒 有 a.txt 其 内 容 为 1 (这 是 从 master 
分 文 继 承 过 来 的 ， 在 feature 疝 动 过 ) 

O 携 有 b.txt 其 内 容 为 2 (这 是 从 feature 
才 新 建立 的 档案 ) 


我 们 用 SourceTree 可 以 查看 较为 漂亮 的 commit 
graph (版 本 图) : 


git-merge-demo X 


Show Remote Branches ”Date Drder v 


4 File Status AllBranches vv [区 
人 Working Copy 
4 Branches 
学 feature 
cmaster 
Tags 


Updats abxtl 
Initial commmit (abxt created) 


Remotes 


由 於 雨 个 分 支 都 有 在 建立 feature 分 支 后 都 做 过 喷 
动 ， 不 过 你 可 能 会 发 现 到 ， 这 两 个 分 支 当 中 ， 和 从 
-分 支点 4 开始 ， 所 做 的 修改 区 没有 互相 衢 突 ， 只 
要 是 过 种 状况 ， 合 供 芷 不 会 发 生 问题 。 接 下 来 我 们 
就 来 执行 “ 合 儒 , 动作 (sit merge)。 


从 下 图 示 中 ， 有 许多 我 想 强调 的 细节 : 


1. 合 供 之 前 ， 先 看 清楚 上 自己 在 哪个 分 支 

2. 合 供 之 前 ， 请 确保 工作 目 人 录 是 乾 潭 的 

3. 合 供 时 请 用 sit merge [ 另 一 个 分 支 ] 来 将 另 一 
个 分 支 的 释 更 合 供 回 来 

4. 你 可 以 从 下 图 看 到 我 打 错 字 了 ， 但 Git 还 会 自 
动 曲 我 执行 正确 的 指令 ， 详 情 请 见 【 第 14 
天 : Gitfor Windows 遗 项 设 定 】 

5. 合 供 成 功 和 后 ， 你 可 以 利用 ， git 1log 但 看 版 本 纪 
杀 ， 你 可 以 发 现 ”* ' 合 们 ,的 过 程 会 自动 建立 
一 个 新 版 本 入 ! 


:Ngit-merge-demo>git branch 
featuFe 


:Ngit-mergqe-demo>git Status 
惜 On branch master 
othing to commit 。 woFking Qim OFky clean 


:Ngit-merkrgqe-demo>git mhege featuFe 
JRNING: You called a Git command named :mrege: 上 。 which does not exist- 
ontinuing under the assumption that you meant "mekhge' 
in @-1 seconds automaticallvy..- 
erge made by the :FecuFrsiue”′ Strategyv- 
pb-txt 1 工 
1 file changed-。 1 insertionC+? 
cheate mode 109644 b-txt 


:Ngit-meFkge-demo>git 1og --oneline 
Merge branch "featuFe 
Updqate a-txt: append NEWU LINE 
hdq hb .txt 
f Updqate 巳 -txt9 
Initial commit 《a-txt ckFeated)> 


:NSit-merge-demo >。 


我 们 看 看 合 供 和 后, 的 分 支 状 况 ， 用 SourceTree 
的 commit graph 来 看 : 


git-merge-demo X 


4 File Status All Branchss V] show Remote Branches Date Order 
Weorking Copy Graph 

4 Branches 本 
feature 外 Update at apPend NEW UNE 


| feature|Add bbdt 


Tags 全 Update atxdti 


Remotes 自 Initial commit (abd created) 


最 后 我 们 来 看 看 合 供 后 的 档案 内 容 ， 确 实 如 我 们 预 
期 的 把 两 个 分 支 中 的 变更 都 给 合 伴 了 : 


:Ng9it-mekgqe-demo >dik 
磁 妓 区 6G 中 的 磁 夸 是 TEMPORRRY 
谱 琴 区 序 眉 :98nn-6999 


G:Ngit-merge-demo 上 的 目 针 
Pei3zviexli6 下 和 二 97:43 
Pei3zierli6 下 和 二 97:43 
Pae13z1Bx1i6 下午 98:12 
peli3xiezxl6 下 和 十 98:25 

2 眉 模 案 

2 个 目 震 
:N9it-mekgqe-Qdemo>tuype 己 -tXt 
EW LINE 


:Ngit-mekgqe-Qemo>tuype hb-txt 


:Ngit-mekge-demo>。 


这 就 是 一 场 成 功 的 “ 合 伐 ，! :-) 


删除 不 必要 的 分 广 


假设 我 们 feature 分 支 逮 会 持续 开发 新 功能 ， 所 以 


可 以 暂时 将 它 留 著 ， 让 后 纺 冰 能 继续 切换 


到 featue 分 支 继 续 开 发 。 


如 果 你 确定 用 不 到 的 话 ， 可 以 


用 9it branch -Q feature 删除 该 分 支 。 


: Ng9it-mekgqe-demo>git hbranch -QQ featuhe 


Deleted branch featuke “was 09dc26ey>- 


在 Git 壬 ， 只 要 没有 执行 过 “〔 合 供 , 的 分 支 ， 都 不 
能 用 上 述 指令 进行 删除 ， 必 须 改 


用 9it branch -D feature 才能 删除 该 分 支 。 


救 回 误 删 的 分 广 


不 过 ， 如 果 你 不 小 心 " 误 删 ， 该 分 文 (feature) 的 
话 ， 则 必须 用 以 下 步 县 救 回 分 文 ， 稍 微 麻烦 一 点 : 


1 . 先 利 用 djit reflod 找 出 该 分 支 (feature) 最 后 
一 个 版 本 的 object id (也 就 是 SHA1 格式 的 物 
件 绝 对 名 称 ) 


2. 执行 sit branch feature <SHA1> 即 可 


如 下 图 示 ， 最 终 逮 是 能 把 误 删 的 feature 分 支 给 救 
回 : 


:Ngit-mergqe-demo>gqit branch 


:Ngit-merkrgqe-dqemo>gqit Fef1log 
HEhNDB<《BOy> : meFrge featuke: Merge made by the "Fecuksiue” Sthategy- 
HEhDB《1>: commit: Update a-txt: append NEW LINE 
HEhDB《27>: checkout: mouing from featuke to mastekr 
HEhNDB《3》>: checkou mouing from master to featuhe 
HEhDB《4> : checkou mouing from featuke to mastekr 
HEhDB《5》>: checkou mouing from mastekr to featuFe 
HEhRDBX6》>: checkout: mouing from featuFe to mastekr 
HEhDB<7>: commit: hdd hb-txt 
HEhRDB《8y>: checkout: mouing from master to featuhe 
HEhRDB《9>: commit: Update atxt9 
HEhDG<197>: commit 《initial>: Initial commit 〈《a-txt cFeated> 


:Ngit-mekrge-demo>git branch featuke cd47287e 
:Ngit-mekgqe-demo>gqit branch 


featuFe 


:Ngit-merge-demo >git 2 RS 
4d 


Wil1l 人 
Wed Oct 16 20:13:41 2913 +9809 


Upqate a-txt: append NEU LINE 
5c5988: el09963ed 
上 uthor : Wil1l 《xxxegmail-com> 
pate : Wed 0ct 16 19:43:58 2913 +0869 
Upqate aa-txt9 
dhb ed4 
有 uthor : | Real 6oRy 


Date : Wed Oct 16 19:43:53 209013 +9809 


Initial commit 〈《a-txt ckeated7> 


:Ngit-merkrge-demo >。 


体 验 一 场 “种 突 的 合 供 ， 


现在 ， 我 们 从 master 分 支 的 最 新 版 (HEaAp) 建 立 一 
个 hotfixes 分 支 / 执行 指 


令 . 9it checkout -b hotfixes 


:Ngit-mekgqe-dqemo>git hbranch 
eatue 


:Ng9it-mekgqe-dqemo>git checkout -hb hotfixes 


wiitched to 性 new hbhranch hotfixes” 


:Ngit-mekgqe-dqemo>git hbranch 
eatuke 
hotf IIxe 


masSteh 


我 们 修改 a.txt 的 第 一 行 ， 把 原本 的 1 修改 
乌 bugfixed: 1， 于 建立 版 本 。 然 后 切换 


回 masteL 分 支 


:Ngit-mekrgqe-demo>tuype aa-txt 

EW LINE 

:Ngit-mergqe-demo>notepad aa-txt 
:Ng9it-mergqe-dqemo>type -txt 
jbugf ixed: 工 

EW LINE 

:Ngit-mergqe-demo>git add  - 

:Ngit-mekgqe-demo>git commit -m "atxt bug 工 IxeQd” 
[hotfixes da64286] a-txt bug fixed 


1 file changed。 1 insekhtioncG+>。1 deletion( 一 > 


:Ngit-merkrgqe-demo>git status 
恬 On branch hotfixes 


othing to commit。 wokking dikectoky clean 


:N9it-merkrgqe-demo>git checkout master 
Switched to branch master 


:Ngit-mekrge-demo>gqit branch 
上 eatue 
hotf ixes 


maste 


接著 7 我 们 在 masteI 分 支 修 改 下 区 七 的 第 一 行 7 
把 原本 的 1 修改 为 bugfixeqd by Will: 1 ,站 建 


:Ngit-mergqe-dqemo>type -txt 


EW LINE 

:Ngit-merkrgqe-demo>notepad a -上 txt 

:Ngit-merkrgqe-demo>type 忆 -txt 
jbugf ixed by Will: 工 

EW LINE 

:Ngit-merkrgqe-demo>git add - 

:Ngit-mekge-demo>git commit -m "atxt bug fixed by Wil17 
[master 3a6fc25] a-txt bug fixed by Wil1l 


1 file changed。 1 insertionC+>。1 deletion(K 一 )> 


:Ngit-merkrge-demo>。 


现在 ， 我 们 两 个 分 支 都 同时 修改 了 a.txt 的 档案 
容 ， 而 且 都 在 同一 行 ， 这 样 的 修改 方式 ， 势 必 引 发 
种 突 ，。 我 们 就 马上 来 体验 一 下 : 


:Ngit-mekgqe-demo>git Status 
On branch mastekr 
othing to commit 。 wokking Qirectorkry clean 


:Ngit-mekgqe-demo>gqit meFkge hotfixes 
上 uto-merging 己 - 上 txXt 
NFL 《content>: Merge conf1lict in a-txt 
所 utomatic mekge failedq;i fix conf1licts and then commit the Fesult- 


:Ngit-mekgqe-demo>gqit Status 
On branch master 
ou haue unmerged paths - 
fix conf1licts and kun "9it commit'""> 


Unmerged paths : 
《use "qit add 《file>---" to maFrk Fesolutiony> 


0 changes added to commit 《use "qit add”"” andAor "qit commit 一 aa "> 


没 错 ， 真 的 征 突 了 ， 而 且 Git 告诉 我 要 自己 修正 (fix) 
这 个 衢 突 (conflicts)。 我 们 用 sit status 可 以 看 出 


目前 发 生 衢 突 的 档案 有 哪些 ， 而 且 你 也 可 以 看 到 这 


个 档案 位 於 Unmerdedq Paths 这 个 区 段 。 


查看 衢 突 的 内 容 


当 你 发 生 种 突 的 时 候 ， 切 莫 慌 张 ， 先 执 
行 sit diff 自动 比 对 出 到 放 哪 些 档案 的 哪 伙 行 发 
生 衙 突 了 。 


:Ng9it-mekgqe-Qdqemo>git Qiff 
IE 一 -CC 六- 七 xc 


NEW LINE 


从 上 图 你 必须 注意 的 是 aiff 针对 征 突 内 容 的 表示 
法 ， 看 的 懂 ， 你 才 容易 知道 怎样 改 : 


。 和 从 <<<<<<< HEAD 到 ======= 的 内 容 ， 代 
表 Hap 壬 a.txt 的 内 容 。 主 : HEaAnp 代表 蚤 
前 masS 七 ee 分 支 的 最 新 版 。 

。 和 从 ======= 到 >>>>>>> hotfixes 的 内 容 ， 代 


表 hotfixes 分 支 壬 a.txt 的 内 容 


解决 备 突 状 号 的 方法 
我 先 来 说 说 上 解决 衢 突 状态 ,的 方法 ， 其 实 很 简 


单 ， 直 接 输 入 sit aqaqa . 把 目前 工作 目 销 的 状态 加 
入 到 索引, 之 中 ， 就 可 以 取消 这 些 Unmerged 档 


案 的 征 突 状态 。 


如 果 你 很 属 ， 遇 到 征 突 什么 都 不 改 ， 直 接 执 

行 sgit add . 再 加 上 cit commnit 的 话 ， 会 
解决 备 突 ，， 但 所 commit 的 版 本 将 会 包含 这 些 
征 突 的 表示 文字 ， 如 果 你 身 处 一 和 肯定 

会 被 晶 翻 到 臭 头 ， 请 你 千 万 不 要 这 户 做 ! 


:Ngit-mekgqe-demo>git Status 
On branch master 
ou haue unmerged paths -. 
《fix conf1licts and Fun ""git commit'""> 


Unmerged paths : 
《use "qit add 《file>---"” to maFrk kesolutiony> 


both modified: 忌 。 七 Xt 
D_ changes added to commit 《use "qit add'"" andAor "git commit 
:Ngqit-mekrgqe-demo>git add  -. 
:Ngit-mekge-demo>git Status 
On branch master 
h11 conf1licts fixed but you ake Still mekrgqing - 


《use "qit commit'" to concludqe meFrge)> 


Changes to be committed: 


:Ngqgit-mekgqe-demo >type aa-txt 
《<<<*《 HEhD 
8 主 


:Ngit-mekge-demo>git commit 
[mastekr 2e37333] Merge branch "hotfixes' 


:Ngit-mekrgqe-demo>git 1og --oneline 


7333 Merge branch : hotfixes” 
) 羡 -txt bug fixed buy Uill 
) 已 -txt hbug fixed 
)” Merge branch "featuke' 
7e Update a-txt: append NEWU LINE 
”hdqd hb .txt 
Upqate -txt9 
Initial commit 《a-txt ckFeated7 


做 销 了 ? 疫 关 傈 ， 只 要 执 
行 9it reset --hardq ORIG_HEAD 就 可 以 回复 到 上 
一 版 ， 然 后 再 重新 合 供 一 次 引发 相同 的 征 突 。 


:Ngit-mekrgqe-demo>git 1og --oneline 

9 Merge branch :hotfixes 
Btxt hbug 上 fixed by Vil1l 

86 a-txt bug fixed 
Merge branch :featue' 

7e Update a-txt: append NEWU LINE 

> 自 Qq hb -txt 

Updqate Ba-txt9 
Initial commit 〈《a-txt cFeated> 


:Ngit-mekgqe-demo>gqit keset -hard 0RIG_HEhD 
EhD is now at 3abfc25 a-txt bug fixed by UVUil1l 


it-merge-demo>git 1og --oneline 
) 己 。txt hbug 上 ixed by Wil1l 
) Merge hbranch “featuke 
Update a-txt: append NEWU LINE 
hdqdq hb .txt 
Upqate aa-txt9 
Initial commit 《a-txt ckheated> 


:Ngit-merkge-demo>git status 
On branch mastekr 
othing to commit 。 wokking directoky clean 


:Ngit-mekgqe-demo>git meFrge hotfixes 
huto-merging atxt 

ONFLICI 《content>: Merge conf1lict in a-txt 
utomatic meFge faileq;i fix conf1licts and then commit the Fesult - 


:Ngit-merkgqe-demo>git status 

On branch mastekr 

ou havue unmerged paths - 
《fix conf1licts and kun 


是 


gdit commit'"> 


Unmerged paths : 
《use "qit add 《file>---" to maFrk Fesolution7> 


both modltTIed: 


0 changes added to commit 《use "qit add”"” andAor "qit commit 一 a "> 


找 出 种 突 的 档案 


当 合 供 发 生 种 突 时 的 档案 数量 很 少时 ， 或 许 直接 

打 sit aiff 可 以 看 得 出 差 时 ， 但 如 果 是 两 个 比较 
大 的 分 支 发 生 种 突 的 话 ， 很 有 可 能 会 有 一 大 堆 档 案 
有 征 突 的 状况。 下 
查看 种 突 的 状况 ， 这 时 你 可 以 用 以 下 两 种 Git 指令 


找 出 种 突 的 档案 : 


执行 9it status 


。 雪 行 git 1s-files -ua 


:Ngit-mekgqe-demo>git Status 
On branch master 
ou haue unmerged paths - 
《fix conf1licts and kun "qit commit'""》> 


Unmerged paths : 
《use "qit add 《file>--.-" to makhk kesolution> 


0 changes added to commit 《use "qit add"” andAor "qit commit 一 aa 


:Ngit-mekgqe-demo>git 1s-files 一 LU 
HL66644 3dqal3al2c85192alb5f2e32bBly?f?4488?7?5a42c 工 
HL66644 e2815echbffa935d5dq55Beaecc592hbh38849a4c64 2 
1L66644 al26f33dcl28dqcaf5e3a281hb42edqa453hbh6333?5Qd 3 


找到 之 后 再 用 sit aiff [filepath] 就 可 以 俊 比 杀 
其 中 一 个 档案 了 : 


:Ngit-mekrge-demo>git Status 
异 On branch mastekr 
性 “ou havue unmekged paths . 
fix conf1licts and kun "9it commit ”> 


性 Unmerged paths : 
《use "qit aqdd 《file>---”to makhk Fesolutiony> 


0 changes added to commit 《use "qit adqdq”"” andAork "“"git commit 一 Ba "> 


:Ngit-mekge-demo>git 1s-files 一 

88644 3dqal3al2c85192alb5f2e32hbBl?f74488775a42c 工 己 - 七 Xt 
La644 e2815echbhffa935d5ddq55geaecc592hb38049a4c64 2 本 区 人 
HL66644 al29f33dcli28dqucaf5e3a281b42eda453hb6333?5d 3 去- 七 Xt 


:Ngit-mekge-demo>git Qiff atxt 
站 王 一-cc 已 -上 txXt 
indquex e2815ec-al29f33. .90060009 
一 /aotXt 
++ ba -tx 


BeB -1.2 -1-2 + 


hot 于 ix 


NEW LINE 


真 的 要 解决 备 突 ， 你 必须 手动 把 这 些 衙 突 的 档案 改 
好 。 不 过 ， 如 果 这 时 使 用 SourceTree 来 修复 衢 突 


的 档案 ， 那 生命 将 会 美好 许多 。 


我 们 开 艇 SourceTree 下 进入 Working Copy 和 节 

点 ， 在 档案 清单 中 按 下 滑 鼠 右键 ， 这 时 有 个 
Resolve Contflicts (解决 种 突 ) 的 选单 ， 这 和 里 你 就 
能 遗 择 你 要 用 我 的 (Mine) 或 是 用 其 他 人 的 (rzheirs) 来 
解决 这 个 档案 的 种 突 状态 。 所 谓 “我 的 , 就 是 你 凡 
前 工作 目 杀 的 那个 分 支 (naster)， 而 了 他 的 ， 就 是 


被 我 们 指定 合 供 进 来 的 那个 分 支 (hotfixes)。 


git-merge-demo X 


器 9nore Whitespace ”Dif 


4 File Status 1 Show Pending ~ 


4 Branches 
演 feature 


1 + <<<<<<< HEAD 
一 hotfixes bei by Will: 
窜 master 
Tags Show in Explorer 二 站 
R Copy Path To Clipboard DR 


External Di 开 
Remove 

Discard 

Stop Tracking 
Unstage from index 


如 果 我 玩 Resolve Using 'Mine' 的 话 ， 他 还 会 出 现 
一 个 确认 合 供 的 视窗 ， 你 按 下 OK 之 后 ， 
SourceTree 就 会 自动 将 档案 中 发 生 种 突 的 那些 段 
落 ， 修 改 成 “我 的 , 版 本 : 


办 Are yousure you want to resolve the following iiles using your own version? 


请 注意 : 当 你 利用 SourceTree 才 你 解决 种 突 和 后 ， 
该 档案 也 会 直接 加 入 到 索引 之 中 (cit add .)， 但 不 


会 攻 你 执行 sit commit 动作 ， 所 以 你 还 要 自己 多 


做 这 一 步 : 


gt-merge-demo Xi 


4 File Status show Pending v 了 contedt- 3tLiness “ 
人 Werking copy 
4 Branches 
党 feature 
喇 hetfixes 
罕 master 
Tags 


Remotes 


输入 一 些 版 本 讯息 人 后， 就 可 以 执行 Commit 动作 ( 
Commit 按钮 在 视窗 右 下 角 ) : 


9it-merge-demc X 


Commit message- 


|Merse branch 'hotfixes' 


Conflicts- 工 
txt 


Recent messages 
shcw Pending 


Commit mode: | Staged changes “ Author |Will <xox@gmailcom> 


.centext 3Linss “ 
? Filename Path 


我 们 来 看 解决 种 突 薄 合 儒 和 后 的 commit graph 如 
下 : 


git-mergs-demo X 


4 File Status All 6ranches v 网 Show Remete Branches Date Drder v 
多 Working copy Graph 
4 Branches 牛 Merge branch 'hotfixes' 
替 feature 】 atxt bug fixed by Wi 
替 hotfixes atxt bug fixed 
二 branch feature' 


Add bbxt 
Update atxt! 
Initial commit (atxt created) 


Tags 内 | Update atxt appsnd NEW LINE 


Remotes 


今 今日 小 颖 


Git 合 供 算是 比较 困 认 的 部 分 ， 但 重点 还 是 在 观念 ， 
观念 正确 了 “， 就 算 发 生 种 突 也 不 用 害怕 。 措 配 好 用 
的 GUI 工具 ， 后 江 
题 。 说 真 的 ， 若 发 生 征 突 时 没有 GUI 工具 ， 光 是 打 
中 令 真 的 会 闯 掉 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git merge [other_branchname] 


git checkout -b [new_branchname|] 


git reflog 


git branch -d [branchname] 


git branch -D [branchname] 


git branch feature 
git reset --hard ORIG_HEAD 
git status 


。git ls-files -U 
。git diff [filepath] 


参考 连结 


*。 BRANCHING AND MERGING 


。 HOME 

。 回 目 凶 

。 前 一 天 : 善 用 版 本 日 读 git reflog 追 跳 弧 更 鸭 
。 下 一 天 : 修正 commit 过 的 版 本 雁 史 纪 杀 Part 


1 (reset & amend) 


第 18 天 : 修正 commit 过 的 
版 本 历史 纪 人 外 Part 1 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/18.md 


当 你 使 用 Git 进行 版 本 控 管 时 ， 我 们 会 利 

用 sit commit 建立 许多 版 本 ， 由 於 Git 属 分 散 式 
版 本 控 管 机 制 ， 对 於 版 本 控 管 方面 没有 太 多 的 权限 
设计 ， 跟 其 他 如 Subversion 或 TFVC 这 类 版 控 系 
统 相 比 ，Git 提供 更 多 上 修正 版 本 记 外 ,， 的 机 制 ， 让 
你 在 “分 享 ,: 版 本 给 其 他 人 的 时 候 ， 人 能够 预先 做 个 


整理 。 


版 本 控 管 的 基本 原则 


我 们 在 进行 版 本 控 管 时 ， 扰 论 是 Git, Subversion 或 
TFVC 都 一 檬 ， 维 持 一 个 良好 的 版 本 纪 欠 有 助 於 我 
们 追 距 每 个 版 本 的 更 新 历程 ( 当 有 需要 做 这 件 事 的 
时 候 )。 以 我 个 人 的 经 验 ， 我 们 很 亲 有 机 会 ， 也 不 大 
想 去 追 跳 我 们 某 个 专案 中 软体 开发 的 进程 ， 我 们 许 


多 专案 累积 的 版 本 纪 从 数量 有 多 过 数 干 笔 ， 谁 会 有 
这 种 闻 工 夫 去 追查 历史 呢 ? 


然而 实务 上 ， 当 软体 的 臭 蝇 (Bug) 发 生 的 时 候 ， 我 们 
会 需要 去 追 跳 特定 臭 蚜 的 历史 纪 人 “， 以 查 出 该 臭 蝇 
真正 发 生 的 原因 ， 这 个 时 候 就 是 版 本 控 管 带 来 最 大 
价值 的 时 候 。 


也 因此 ， 要 怎样 维持 一 个 好 的 “版 本 纪 人 4 也 是 非 
常 重 要 的 ， 过 下 有 一 些 控 管 原则 可 以 分 享 给 大 家 : 


。 做 一 个 小 功能 修改 就 建立 啤 本 ， 过 
跳 变 更 

。 干 万 个 要 累积 一 大 堆 修改 后 才 建立 一 个 " 大 版 
本 ， 

。 有 选辑 、 有 顺序 的 修正 功能 ， 确 保 相关 的 版 本 
修正 可 以 按 顺序 提交 (commit)， 这样 才 便 於 追 


路 


二 
~ 上 


这 才 容 易 追 


不 过 ， 人 非 蛙 属 、 熟 能 无 过 ， 哪 个 人 能 确保 团队 所 
有 人 都 能 时 时 刻 刻 照 著 上 述 原则 进行 版 控 ? 哪个 人 
不 是 ' 想到 哪 改 到 哪 , 呢 ? 这 样 的 要 求 释 得 有 点 缘 
木 求 急 、 不 切实 际 。 所 以 ， 我 们 需要 有 一 套 ' 修改 
版 本 : 的 机 制 ， 让 版 本 提交 到 踪 端 伺服 器 上 的 时 
候 ， 就 已 经 是 完美 的 版 本 状态 。 


修正 commit 历史 纪 色 的 理由 


到 目前 为 止 ， 我 迁 没 提 到 关於 ' 下端 储存 库 , 的 细 
和 节 ， 所 以 大 部 分 的 Git 操作 都 还 专注 在 本 地 端 ， 也 
就 是 在 工作 目 人 录 下 的 版 本 管控 ， 这 个 储存 庆 就 位 於 
你 的 .sit/ 目录 下 。 然 而 ， 之 后 我 们 即将 提 到 “' 踪 
端 储存 库 ,， 的 雁 用 ， 到 时 就 不 只 一 个 人 扒 有 储存 
库 ， 所 需要 注意 的 细节 也 就 更 多 。 


完全 开放 每 个 人 都 能 级 任意 的 修正 commit 历史 纪 
销 ， 这 个 概念 对 於 熟悉 Subversion 或 TFVC 的 人 
来 说 或 许 匠 起 来 非常 很 奇怪 ， 因 么 以 往 大 家 都 集中 
过 接 到 版 本 控 管 的 伺服 器 上 ， 用 的 是 集中 式 的 储存 
库 ， 如 果 有 人 可 以 任意 韦 改 历史 纪 休 “， 那 版 控 还 叫 
做 版 控 吗 ? 


其 实在 Git 版 本 控 管 中 ， 概 念 是 一 样 的 ， 只 要 同一 
份 储 存 库 有 多 人 共用 的 情况 下 ， 若 有 人 任意 穴 改 版 
本 ， 那 冻 Git 版 本 控 管 一 样 会 乱 法 正常 到 作 。 


所 以 ， 到 底 甚 庆 样 的 使 用 情境 会 需要 去 修改 版 本 纪 
外 呢 ? 以 下 绑 黑 各 位 可 以 参考 看 看 。 


假设 我 们 现在 有 [A] -> [B] -> [C] 三 个 版 本 : 


。 可 能 [C] 版 本 你 发 现 commit 错 了 ， 必 须 删 除 
这 一 版 本 所 有 继 

。 你 可 能 commit 了 之 后 才 发 现 [C] 这 个 版 本 其 
实 只 有 测试 程式 码 ， 你 也 想 删 除 他 

。 其 中 有 些 版 本 的 纪 杀 讯息 有 错字 ， 你 想 修 改 讯 
息 文 字 ， 但 不 影响 档案 的 释 更 厅 程 

。 你 可 能 想 把 这 些 版 本 的 commit 顺序 调整 为 [A] 
-> [C] -> [B]， 让 版 本 演进 更 有 逮 辑 性 

。 你 发 现 [B] 这 个 版 本 忘 了 加 入 一 个 重要 的 档案 
就 commit 了 ， 你 想 事后 补救 这 次 变 

。 在 你 打算 分享, 分 支出 去 时 ， 发 现 了 程式 码 
有 瑕 瘦 ， 你 可 以 修改 完 后 再 分 享 出 去 


修正 commit 历史 纪 色 的 注意 事项 


Git 保留 了 修改 版 本 历史 纪 凶 , 的 机 制 ， 主 要 是 希 
望 你 能 在 “自我 控 管 版 本 4, 到 了 一 定 程度 人 后， 自己 
整理 一 下 版 本 纪 俏 的 各 种 资讯 ， 好 让 你 将 版 本 " 发 
布 : 出 去 后 ， 让 其 他 人 能 弧 更 清楚 的 理解 你 对 这 些 
版 本 到 搬 做 了 哪些 修改 。 


所 以 ， 修 改版 本 历史 纪 杀 时 ， 有 些 事情 必须 特别 注 


ES 
VIA 。 


。 一 个 储存 库 可 以 有 许多 分 支 ( 预 设 分 支 名 称 


声 masteL) 
“分享 Git 原始 码 的 最 小 单位 是 以 分支: 筷 单 
位 


。 你 可 以 任意 修改 某 个 支线 上 的 版 本 ， 只 要 你 膛 
没 “ 分享: 给 其 他 人 
。 当 你 ' 分享: 特定 分 支 给 其 他 人 之 和 后， 这 些 


已 分 享 : 的 版 本 历史 纪 俏 融 别 再 改 了 ! 


准 位 本 日 练 避 用 的 版 本 库 


之 前 我 们 曾 在 【第 04 天 : 常用 的 Git 版 本 控 管 指 

令 】 学 过 sit reset 的 用 法 ， 主 要 用 来 重 置 目 前 
的 工作 目录 。 不 过 ， 相 同 的 指令 ， 也 可 以 用 来 修正 
版 本 奈 史 纪 色 。 


在 开始 说 明 前 ， 我 们 一 样 先 用 以 下 指令 建立 一 个 张 
剖 用 的 工作 目录 与 本 地 储存 库 : 


和 KG goeseeSsetkEasmc 
cq dg9it-reset-dqemo 


Gile 


SEO 之 至 忆 现 巧 : 臣 


9it aqdd 


人 CEG) 


Se 二 ECE 
二 人 忆 


geCOTEL TO 本 本 六 攻 ” 


ELIEAE 
meiolel 
4 和 遇 本 ein 区 wisets 


西 CNwindows\system32NXcmd,exe 


:N\>mkdir ggit-Feset-demo 
:N\>cd 9git-keset-dqemo 


:Ngit-Feset-demo>git init 
Initialized empty Git kepository in C:Agit-Fheset-demo-g9it~ 


:Ngit-Fkeset-demo> 
:Ngit-Feset-demo>echo 。 > -txt 


:Ng9it-Fkeset-demo>git add - 

:Ng9it-Feset-demo>git commit -m “Initial commit 《aa -txt ckeated>” 
[master 《khoot-commit》 83a8419] Initial commit 〈《a-txt cFeated7 

1 上 ile changed。 1 insertionC+) 


cheate mode 199644 a-txt 


:Ngit-Feset-demo> 
:Ng9it-Fkeset-demo>echo 1 > atxt 


:Ng9it-Feset-demo>git add -. 
:Ngit-Feset-demo>gqit commit -mv 咱 pdate 性 -txtg 
[mastekr 95?76eghb] Update a-txt9 


1 file changed。 1 insekrtionG+>。 1 deletion( 一 > 


:Ng9it-Feset-dqemoy> 
:Ngit-Fkeset-demo >echo 1 > b.txt 


:Ngit-Feset-demo>git add - 


:Ngit-keset-demo>git commit -m "hdd hb-txte 
[master aef2ao5f] hddq b.txt9 

1 file changed。 1 insertionC+》 

chFeate mode 1969644 b.txt 


it-Feset-dqemo> 


以 上 建立 了 三 个 版 本 ， 执 行 sit 1log 的 结果 如 下 国 


小 


西 CNwindowsNsystem32Ncmd.exe 


:Ngit-Feset-demo>git 1og 


huthor: WUill 《xxxegmail.comy> 
IDpate : Fri Oct 18 21:36:56 2013 +0800 


hdq hb-txt9 


huthor: Will 《xxxegmail.-com> 
IDpate : Fri Oct 18 21:36:56 2013 +0800 


Updqate aa-txt9 


huthor: Vil1l 《xxxegmail.-comy> 
IDate : Fri Oct 18 21:36:56 2013 +0800 


Initial commit 〈《a-txt ckheated7> 


:Ngit-Feset-demo>。 


删除 最 近 一 次 的 版 本 


我 们 参考 上 图 ， 用 文字 表达 这 三 个 版 本 的 | 
下 : 


自序 如 


ESSa844 可 属 之 出 L0S6s 0 改过 [sef2a5l 


现在 ， 我 想 把 最 后 一 个 版 本 删除 ， 释 


[83a841] > [0576e0] 


那 闵 ， 你 可 以 执行 sit reset --harq "HEAD^" 即 
可 删除 azap 这 个 版 本 : 请 注意 : 在 上 命令 提示 字 
元 下 “^ 是 特殊 符号 ， 所 以 必须 用 多 引号 括 起 来 ! 


CNwindowsNsystem32N\cmd.exe 


:Ngit-Pkeset-demo>gqit heset --hard "HERD^ 人 " 
EhD is now at 85?6eghb Update aa-txt9 


:Ngit-Feset-demo>git 1o9 


huthor: Vi1lL1 《xxxegmail.-com> 
Fri Oct 18 21:36:56 2013 +0809 


Update aa-txty 
huthor: UVUill 《xxxegmail.com> 
Fri Oct 18 21:36:56 20913 +09869 


Initial commit 《〈《a-txt cheatedy) 


:Ngit-Feset-demoy> 


此 时 你 可 以 看 见 ， 原 本 的 最 新 版 被 删除 了 ， 那 是 因 
为 刚刚 我 们 执行 sit reset --hard "HEAD^" 这 个 
动作 ， 把 azap 指向 的 位 址 改 到 了 前 一 个 版 本 

( HEAD^ )， 所 以 你 打 sit 1log 就 看 不 到 这 个 版 本 
本 


事实 上 ， 原 本 你 感觉 被 删除 的 版 本 ， 其 实 一 直 储存 

在 Git 的 物件 储存 区 (object storage) 壬 ， 也 就 是 这 

笔 资 料 一 直 躺 在 .sit\objects\ 目 杀 下 。 我 们 还 是 
可 以 用 sit show 83a841 取得 该 版 本 ( 即 commit 

物件 ) 的 详细 资料 : 


西 CNwindowsNsystem32\cmd.exe 


:Ng9it-keset-demo>gqit show 83a841 


"二 Uill 《xxxegmail-comy> 
Fri Oct 18 21:36:56 2013 +0800 


Initial commit 〈《a-txt cheated7 


IE 一 -gt aa-txt ba-txt 
ew file mode 1099644 

index _ 09086669. .8dqlc8hb6 

-- vdeuvnu11 

+++ ba-txt 


删除 最 近 一 次 的 版 本 ， 但 保留 最 后 一 次 
的 变更 


还 记得 唉 ? 无 论 你 对 Git 储存 库 做 了 什么 事 ， 都 是 
可 以 还 墅 原 的 7 只 要 者 


行 Sit reset --harq ORIG_HEAD 即 可 。 


画 CNwindows\system32NXcmd.exe 


:Ngit-eset-demo>git keset --hard 0RIG_HEhD 
EhD is now at aef2a5f hdq b.txt9 


:gdit- eset-demo >git 9 各 
本 4DS433f 


of9cod4f35695c?744 
WE Will 《XXXBgmai ER》 
Fri Oct 18 21:36:56 2013 +0800 


hb .txt 


Fri Oct 18 21:36:56 2013 +0800 
Update aa-txt9 
AS41D9hbof5e7hbhl52eh 
"二 Uill 《xxxegmail-comy> 
Fri Oct 18 21:36:56 2013 +0800 


Initial commit 〈《a-txt cheated) 


:Ngit-Feset-demo>。 


另 一 个 删除 版 本 的 技巧 ， 则 是 “删除 最 近 一 次 的 版 
本 纪 休 ， 但 留 下 最 人 后 一 次 版 本 释 更 的 暴动 内 容 ，， 
这 时 你 可 以 执行 git reset --soft "HEAD^" 巡 成 
这 个 任务 : 


框 CNwindowsNsystem32Ncmd.exe 


:Ngit-Peset-demo>git Feset 一 -Soft "HEhD^ 人 " 


:Ngit-Feset-demo>git 1og 
J)mmit 6576eghbgo72dhb?7f5687c8Sc5 gc8i4965977cb6 
huthor: Vil1l 《xxxegmail.-comy> 

Date : Fri Oct 18 21:36:56 2013 +0860 


Upqate aa-txt9 


mmit 83a8410hbhof5e7hbhl52eh3efg040557hb5du3e23f394f 
huthor: WUil1l 《xxxegmail.com> 
Date : Fri Oct 18 21:36:56 2013 +0800 


Initial commit 《aa-txt cheated7 


:Ngit-Feset-demo>git status 
性 On branch mastek 
性 Changes to be committed: 
《usSe ""git keSset HEhD 《file>-.-.-”"”to unstage7? 


:Ng9it-Feset-demoy> 


这 代表 著 ， 你 可 以 保留 最 后 一 次 的 变更 ， 再 加 上 一 
些 弧 更 和 后 ; 重新 执行 何 工 攻 已 OmmiaL 蕊 一 伙 7 站 重新 设 
定 一 个 新 的 纪 从 讯息 。 


重新 提交 一 次 最 后 一 个 版 本 ( 即 map 版 
本 ) 


如 果 你 发 现 不 小 心 执 行 了 sit commnit 动作 ， 但 还 

有 些 档 案 忘 了 加 进去 (ait adda [filepath]) 或 只 是 
纪 销 讯息 写 错 ， 想 重新 定 上 的 话 ， 直 接 执 

行 git commit --amend 即 可 。 这 个 动作 ， 会 把 目 

前 纪 杀 在 索引 中 的 变更 档案 ， 全 部 添加 到 当前 最 新 


版 之 中 ， 下 且 要 求 你 修改 原本 的 纪 销 讯息 。 


我 们 再 执行 一 次 git reset --hard ORIG_HEAD 复 
原 到 原本 的 状态 。 


底下 我 试 著 多 新 增 一 个 c<.txt 档案 上 去 ， 然 后 直接 
执行 git_ commit --amend 命令 ,这 时 会 跳出 指定 
的 文字 编辑 器 进行 编辑 ， 且 预 设 会 把 目前 这 次 的 讯 
息 也 给 卦 上， 你 只 要 修改 一 下 就 可 以 了 


画 CNwindowssystem32\cmd.exe - git commit --amend 


:Ng9it-Feset-demo>git 1og 
commit aef2a5cf9cg94f3595c?744695433f1f5tctc39adac9 
huthor: Will 《xxxe@gmail.-com> 
Fri Oct 18 21:36:56 2913 +9809 


haqdq b.txt? 
ommit 日 - 5 ? 814965 


huthor: WUill 《xxxegmail.com> 
Date : Fri Oct 18 21:36:56 20913 +9889 


ET 


ommit 83a8410hbaf5e7hbhl152ehb3ef9469557hb5d 
huthor: Will 《xxxB@gmail.-com> 
Eri Oct 18 21:36:56 2913 +9899 
Initial commit 〈《a-txt ckheated) 
:Ngit-Fkeset-dqemo>git status 
On branch master 
othing to commit 。 wokking directoFry clean 
:Ngit-Fkeset-dqemo >echo 1 > c-txt 


:Ngit-Feset-demo>git add - 


:Ngit-Fkeset-demo>git commit 


on branch master 


砷 砷 砷 砷 砷 瘦 站 


new file: b.TXxTt 
new file: 性 二 X 


厘 沐 


我 把 纪录 讯息 修改 成 以 下 文字 ， 兹 且 存 档 和 
版 本 就 会 建立 完成 


ele 国 josaenu 
ele 必 eepael 


Please enter the commil 
with “##”wil11 be ignor 


changes to be committel 


《use “git reset HEAD, 


慨 退 出 ， 


执行 的 结果 如 下 ， 但 最 值得 注意 的 是 ， 最 新 版 

的 HEap 已 经 是 完全 不 同 的 commit 物件 了 ， 所 以 
用 sit 1log 所 看 到 的 commit 物件 绝对 名 称 跟 之 前 
已 经 不 一 样 了 。 


:Ngit-Freset-qemo>git commit 一 -amenaQd 
[mastekr 5feghbf5] haqq b-txtey haqdq c-txt9 
2 files changed。 2 inseFtionsC+? 
ceate mode 1969644 hb-txt 

Cheate mode 1069644 c -txt 


9git-keset-demo>gqit 1og 
DOmmit 上 >Dhbfo5cd49hbehb8hbhphi 
huthor: WUi1L1L 《xxxegmail.com 
Date : Fri Oct 18 21:36:56 2013 +0800 


hdqd hb-txt9 
haqq c -txt9 


mm1l 上 9hbgy72dh2f5687c8 
huthor: WUil1l 《xxxegmail.-com> 
Date : Fri Oct 18 21:36:56 2013 +0800 


Upaqaate -txte 


Commi 93a84109hbof5e7hbhl52ehb3ef94955?7hb5 
huthor: WUil1l 《xxxegmail.comy> 
Date : Fri Oct 18 21:36:56 2013 +09800 


Initial commit 《a-txt ckFeatedy> 


:Ng9it-Fheset-demo>git Show HEhD 
5cfeghbf5dq49hbehb8hbhbfel98f724 
huthor: WUill 《xxxegmail.-com> 
Date : Fri Oct 18 21:36:56 2013 +09800 


hdqd btxt9 
hdqq c .txt 


IE 一 -9it ahb-txt hbhb -txt 
ew file mode 1060644 

indquex 0D00008 . .37hbcc8h 

-- vdeunul11 

+++ bnhb .txt 


目 
EE 一 -9it ac -txt bc -上 txt 
ew file mode 1069644 
indqex 0600008 . .37hbcc8h 
-- vdqeuvnul11 
++ bc -txt 


今日 小 续 


今天 简单 的 学 到 如 何 对 【最 新 版 】(Hzap) 进 行 版 本 


的 继 更 ， 大 多 用 在 不 小 心 sit commit 错 的 情况 ， 
事实 上 还 会 有 更 多 调整 版 本 历史 纪 销 的 方式 ， 这 些 
会 在 之 后 的 文章 中 出 现 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git reset --hard "HEADA^" 
。git reset --Soft "HEADA^" 

。git reset --hard ORIG_HEAD 
。git commit --amend 


W 


参考 连结 


。git-reset(1) Manual Page 


。 前 一 天 : 关於 合 供 的 基本 届 念 与 使 用 方式 
:gl 


。 下 一 天 : 设 定 .gitignore 忽略 清单 


第 19 天: 设 定 .gitignore 久 
略 清 单 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/19.md 


在 开发 专案 时 ， 工 作 目 录 下 可 能 经 常会 有 新 的 档案 
产生 (可 能 是 透 过 Visual Studio 工具 产生 的 那些 暂 
存档 案 或 快 取 档 案 )， 可 能 有 许多 档案 焉 不 需要 列 入 
版 本 控 管 ， 所 以 必须 要 排除 这 些 档案 ， 我 们 称 为 


『 : 主 
忽略 清单 Jo 


关於 .gitignore 档案 


在 Git 里 面 ， 是 透 遇 .sitignore 档案 来 进行 定义 
忽略 清单 ，， 主 要 的 目的 是 排除 一 些 不 需要 加 入 
版 控 的 档案 ， 列 在 壬 面 的 档 名 或 路 径 (可 包含 万 用 
字 元 )， 都 不 会 出 现在 sit status 的 结果 中 ， 自 然 
也 不 会 在 执行 sit adad 的 时 候 被 加 入 。 不 过 ， 这 仅 
限 於 untrackeaqd file 而 已 / 那些 已 经 列 入 版 控 的 


档案 (Staged file) 不 受 .9it1ignore 档案 控制 。 


过 GitHub 建立 预 设 的 忽略 清单 


如 果 你 曾经 在 GitHub 建立 过 专案 ， 可 能 会 用 过 这 
国力 阴 ， 就 在 Ra es ， 可 以 
让 你 选择 GitHub 预先 帮 你 定义 好 的 忽略 清单 ， 这 
由 忽略 清音 其 实 就 只 是 一 个 档案 而 已 ， 其 榴 名 

为 .gitignore， 亚 预 设置 於 专案 跟 目 朱 人 下 。 


() 血 外 ”Explore Gist Blog Help 
Owner Repository name 
围 doggy8088 - /sandbox-csharp W 


Great repository names are short and memorable_ Need inspiration? Ho， 


Description (optional) 


国 上 Public 
Anyone can Seetihis repositor. You choose who can commit 


Private 
You choose who can See and committo this repository 


多 


Initialize this repository with a README 
This will allowyouto it clonethe repository immediatehy 


Add a license- None ~ 


我 们 以 上 图 这 个 CSharp 专案 为 例 ， 建 立 完成 后 ， 
在 储存 库 中 就 会 出 现 一 个 预 设 的 .sitignore 档 


本 
亲 : 


doggy8088 / sandbox-csharp 


Description 


1 1 bra 


P branch: master ~ ， sandbox-csharp /加 


， 


README.md 


四 


我 们 可 以 看 看 其 内 容 : https:/github.corn/ 
doggy8088/sandbox-csharp/blob/master.gitignore 


# BuUila ERolaesrzs 
喇 i 是 Wan 
[EGeliiea 光 


(You can keepP bin if you'd 1ikey， 


# mstest tt 上 est results 


TestResults 


## Ionore Visual Stuadio 七 smporary files，， build YE 


## Eles generatedq by Popular Visual Studio adqdq-- 


人 二 下 二 总 用 区 和 二 ee 


DYG) 


厅 


Se 


sinasseoestaees 


BadaiaeossssUdgses 


[Ddq] epugy/ 


[Rzlelease/ 
X64/ 


ETG 


0 


大 


大 


大 


大 


大 


天 


2 的 国 R 
Sea 
局 可 
二 ojelyi 
遇 oiole 
eele 
晤 ofelel 
SI 
FEEr 
EN 
由 
Ni 
erTiI 
ee 
wsesee 


NSSSIGC 


Dalis 


# Visual C++ cache files 
SGei 

区)S 

ee 

* .Opensdf 


SO 


# Visual Studqio Profiler 
* .PSesSs 
AS 


大 人 记 区 


# Guidance Automation Too1l1kit 


eaooeaee 


SSEESes 人生 语 NhoEeciehole 攻 = 二 am 
_ReSharPeIrr* 


# _ NCFunch 
enEDUOUGHNES 


SDDS Eee 人 KI 


# Installshieldq output folqer 


[Ee]lxPress 


# DocProject is a qdqocumentation denerator adqdq-1in 


DocProject/buildhelLP/ 


DocProject/HelLP/*.HxTI 


一 


BocEYEoaee ED 全 日 六 他 


弄 


DocProject/HelLP/x* .hhc 


导 ， 


DocProject/HelLP/* .hhk 


汉 ， 


DocProject/HelLP/x* .hhp 


昌 。 


DocProject/HelLP/HLm12 


Re 


DocProject/HeLIP/htm1l 
# ClLick-once Qirectory 
lel 用 放 


# PublLish Web Output 
大 ES 文 Ti 下 


# NuGet Packages Directory 


Packades 


# Windows Azure Build OutpPut 
CSX 


GCCSGe 


# Winadaows Store apP package qirectory 


APPPackages/ 


# Others 
[ 节 记 ] 二 而 
[ooj]p】 

= < 


TeskResultes 

服用 二 | 医 ==55 卫 s 人 a 攻 = 古 力 党 

Cacehme 

GETIEBDN 

ISSNRENESIEBGIECIO RS 

本 Sewx 

oa 可 

Generatedq_Ccodqde :上 #aqdqedq for RIA/SiLVer1light Projec 


# Backup & report files from converting an old P 
# Visual Studqio version。 Backup files are Phot ne 
_UPgzadeRepPort_Eiles/ 

Backupr*/ 

UpgradeLogrx .XML 


这 些 内 容 ， 真 的 就 是 在 用 Visual Studio 写 CSharp 
专案 时 常见 的 “忽略 清单 ， ， 非 常 具有 实用 价值 ， 
如 果 各 位 迁 有 一 些 额外 的 档案 名 称 或 路 径 要 加 入 ， 
也 可 以 自行 添加 在 这 个 档案 里 面 。 


少 


参考 其 他 程式 语言 的 .sitignore 内 容 箔 


讨 


在 GitHub 上 面 ， 事 实 上 簿 提供 了 很 多 其 他 开发 环 
境 所 需 的 .sitignore 范本， 也 都 非常 值得 参考 : 


Owner Repository name 


留 doggy8088 ~ / sandbox-others 
，vgitignore 
Gre iinspiratior 


Des | 


None 全 


AciionSscript 
的) 


坟 Android In commit 


避 | AppceleratorTitanium 
ltory 
Autotools 


忆 Bancha 
| ate 他 
CC | 
me - 
C++ | 


区 CFWheels 


CMake 
CsSharp 


CakePHP 
GitHub, Inc。 Terms movacoymmemeanapmmeremearor 


今日 小 短 


今天 的 .citignore 档案 ， 我 们 继 乎 每 个 专案 都 会 
用 到 ， 算 是 使 用 Git 时 一 个 必 人 备 的 重要 档案 。 


参考 种 结 


。gitignore(5) Manual Page 


Subversion 


HH 


.请 勿 将 某 些 档案 类 型 的 档案 签 入 


版 本 库 (二 版 ) 


*。 HOME 


。 回 目 销 

。 前 一 天 : 修正 commit 过 的 版 本 雁 史 纪 杀 Part 
1 (reset & amend) 

。 下 一 天 : 修正 commit 过 的 版 本 历史 纪 杀 Part 


2 (revert) 


第 20 天 : 修正 commit 过 的 
版 本 历史 纪 外 Part 2 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/20.md 


在 版 本 控 管 过 程 中 ， 还 有 个 常见 的 状况 ， 那 就 是 沼 
执行 了 多 个 版 本 之 和 后， 才 发 现 前 面 有 关 个 版 本 改 错 
了 ， 例 如 你 不 小 心 把 测试 中 的 程式 码 也 给 commit 
进去 ， 半 致 目前 这 个 版 本 发 生 了 问题 。 这 时 你 就 必 
须 了 解 本 篇 文章 所 说 明 的 内 容 。 


准 位 本 日 练 避 用 的 版 本 库 


在 开始 说 明 前 ， 我 们 一 样 先 用 以 下 指令 建立 一 仙 练 
避 用 的 工作 目录 与 本 地 储存 库 。 我 们 先 建立 一 

个 a.txt 的 档案 ， 内 容 为 1。 然 后 修正 一 版 ， 内 容 
改 为 2。 接 著 在 新 增 一 个 b.txt 档案 ， 内 容 为 1。 

所 以 一 共有 三 个 唉 本 : 


mkadir 9it-zevet-dqemo 


cq dit-revert-dqemo 


Gaiennaiie 


SChmoal 王 二 忆 区 已 
癌 工 二 刘 忆 加 O 


GEEeCiie IRONEEULecie RSIEEOE 


SB 太一 > 
全 工 二 二 QQ 二 


加 工 上 上 本 CCGmma 有 二 仙 恒 “ 厅 认 加 S 放 和 症 有 让 下 


EGOERU > 荐 加 现世 区 起 
本 es 
GTERECOmnma = 矶 呈 页 加 加 总 文 站 


:Ng9it-keuekt-demo>gqit 1o9g 


huthor : Will 《xxxegmail.-comy> 
IDate : Sun Oct 209 18:51:15 2013 +0800 


haddqd b-txte 


huthor: Vil1l 《xxxegmail.-comy> 
IDpate : Sun Oct 209 18:51:15 20913 +0809 


Upqate 习 -txt9 


huthor: Vi1lL1l 《xxxegmail.-com> 
Sun Oct 209 18:51:15 2013 +0800 


Initial commit 〈《a-txt cheated7> 


CEeated) 


假设 我 们 这 个 时 候 发 现 ， 在 我 们 上 一 个 版 本 

( HEAD~ 或 HEAD^ 或 6351ff0 ) 被 改 错 了 ， 你 希望 
可 以 将 该 版 本 迁 原 就 好 ， 而 不 是 把 版 本 重 置 到 第 一 
版 再 重 改 一 次 ， 那 床 你 可 以 试 试 git revexrt 指 
令 ， 他 可 以 把 某 个 版 本 的 变更 ， 透 遇 ' 相反 , 的 步 
县 把 变更 给 逮 原 。 


何谓 ' 相反 , 的 步 屋 呢 ? 我 们 立刻 来 试 试 这 个 指令 
的 用 法 。 


使 用 G9it zeVeLt 命令 


假设 我 们 从 sit 1os 显示 的 历史 记 杀 中 ， 发 现 有 个 
版 本 有 问题 ， 那 诬 我 们 可 以 先 看 看 这 个 版 本 的 释 
纪 杀 。 如 下 图 示 ， 你 可 以 先 用 sit 1los 查 出 版 本 编 
号 ， 然 后 再 用 sit show [commit_id] 查 出 该 版 本 
的 相关 资讯 。 


:Sit- 机 QUemo >9 it 


mmit SS95dd3e93phfd9 5cf7a9466h84fd652349 
二 Will 《XXxxBgmail- 有 
IDate : Sun Oct 29 18:51:15 2013 +0800 


haqq b-txte 


mm 51EE94541a65hb8 | 
huthor: VUill 《xxxegma oOm> 
IDpate : Sun Oct 29 18:51:15 2013 +0800 


Updqate aa-txt9 


)mmit d9fd622a58d6e5859hb3chbcad4de9dga772c6a3e2hbh 
huthor: Vil1l 《xxxegmail.-comy> 
Sun Oct 209 18:51:15 20913 +0809 


Initial commit 〈《a-txt cheated7 


: Ngit-Peuet 一 人 人 全 ee 6351ffO 
6351ff94541a65b82df6ef2cehbhlaachbh55ge2eag28 
:Wil11 台中 交 
Sun Oct 209 18:51:15 2013 +0800 


Updqate 己 - 上 txt 


If 一 -gt aa-txt ba-txt 
index 3?7hbhcc8hb. -8f6cle5 106644 
一 一 BAa txt 

+++ ba -txt 


:Ng9it-keuerkrt-demo > 


请 注意 意 : 执行 gjit zevett 命令 之 前 5  。: 
作 目 凶 是 乾 泽 的 ! 如 果 有 改 到 一 半 的 档案 ， 建 议 可 
透 过 gilit stash 建立 暂 5 存 版 本 。 


从 上 图 你 可 以 看 到 5351ffo 这 个 版 本 的 a.txt 档 
案 ， 是 将 第 1 行 的 内 容 从 :1 修改 成 2 的 ， 那 也 代 
表 著 ' 相反 的 步 嫩 则 是 把 2 改 成 1 才 对 。 这 

时 ， 如 果 我 想 把 这 个 版 本 的 释 更 给 还原， ， 则 可 


以 输入 sit revert 6351ff0 这 个 指令 ， 执 行 成 功 
后 会 额外 再 建立 一 个 新 版 本 。 如 下 图 示 : 


:Ngit-Feuert-demo>git Feuert 6351ffD 
[masteFr ?aece8a]l Reuert ' 咱 pdate 忆 -txte 
1 file changed。 1 inserhtionC+>。 1 deletion(-)》 


:Ngit-Feuert-demo>gqit 1og 
mmit 7 |] b8419? 
: Will 《xxxegmail.com> 

Sun 0ct 29 19:109:17 20913 +9899 


This Feuerts commit 6351ff094541a65b82df6f2cehblaachb550e2eag28 . 
mm 直 d 1 站 | 46t 14i{ 
huthor: Will 《xxxegmail.com> 
Sun 0ct 29 18:51:15 20913 +9899 


hdqdd hb-txt9 


huthor: Wil1l 《xxxegmail.com> 
Sun Oct 29 18:51:15 2013 +D869 


Upqate a-txt9 


( vd4e9d 
hb3: 4 ， 


huthor: UVUil1l 《xxxegmail.-com> 
Sun Oct 29 18:51:15 2913 +98909 


Initial commit 《a-txt cFeatedy)> 


执行 过 程 中 会 让 你 编辑 最 后 要 commit 的 讯息 ， 预 
设 会 加 上 Revert 字样 ， 还 有 会 在 第 三 行 的 地 方 加 
上 This evetrts Commit XXXX 告诉 你 褒 这 个 版 本 


主要 目的 是 从 xxxx 版 本 还 原 的 。 


Fille Edit Yiew Settings 2 
D 忱 可 怠 筷 鱼 | 的 才 | 国 | 和 Q 


Revert “Update a.txtli" 


月 


辐 用 


This reverts Commit 6351lff04541a65b82df6f2ceblaacb550e2ea028. 


震 Please enter the commit message for your changes. Lines starting 
洗 With “ 孝 ”wil11 be ignored，and an empty message aborts the commit . 
才 On branch master 

## Changes toO be committed : 

大 (use “"git reset HEAD <file>...” to unstage) 

才 modified: a.TXT 

源 


从 最 新 版 的 变更 中 ， 你 也 可 以 看 出 ， 过 次 版 本 主要 
将 a.txt 内 容 第 1 行 的 2 改 入 1 的 ， 刚 好 跟 原 
的 释 更 相反, 。 


ht dc8et 

huthor: Wil1l 《xxxegmail.com> 

IDpate: Sun 0ct 29 19:10:17 20913 +9869 
Revert "Upqate aa-txte 


This reueFrts commit 6351ffg94541a65b82dqf6f2cehblaachb55gbe2eag28 - 


革 EEE 一 -9it aa-txt ba-txt 
index 8f6cle5..37hbcc8hb 169644 


:Ngit-PeueFt-demo>git show 6351ffD 


4 4 f 
4 b 1 二 上 hb 


VUill 《xxxegmail-com> 
Sun Oct 29 18:51:15 2913 +9800 


Upqate a-txt9 


一 -9it aa-txt hbva-txt 
index 37hbcc8hb. .8f6cle5 169644 


使 用 git evett 命令 失败 的 情 ; 


事实 上 ， 这 个 sit revert 是 执行 了 上 人 合作， 的 动 
作 ， 我 们 来 证 明 这 个 过 程 。 我 们 在 还 原 了 6351ffo 
这 个 版 本 和 后， 这 个 a.txt 的 内 容 释 成 了 1， 然 而 我 
再 修改 一 次 a.txt 档案 ， 这 次 把 内 容 修改 为 3， 如 
下 力 示 


:Ngit-Feuert-demo>tuype 己 -txt 


:Ngit-Fkevuert-demo>echo 3 > a-txt 
:Ngit-heuert-demo>git add - 


:Ngit-FeueFrt-demo>git commit -m "pdate a-txt to 2 3 
[master d342895] Upqate aa-txt to 23? 
1 file changed-。 1 insektionCt+t>。1 deletionKC 一 ) 


:\S 让 - Feuert-demo>gqit 1og 
5941185 La6ehbf62e?fe6ce7 


WUill 《xxxegmail- 5oay 
Sun Oct 29 19:58:19 2013 +98969 


Upqate a-txt to :3 
egoodua8 和 二 clc3efehbdaadaghb 


Uill 《xxxegmail-com> 
Sun 0ct 29 19:19:17 20913 +D869 


ReueFt '" 咱 pdate atxtg 7 


This Feuerts commit 6351ffg94541a65hb82df6f2cehblaachb55ge2eag28 - 
5ca895ddq3e93pbfd9f195f 7 hb8S4fd65: 
UillI 《xxxegmail-com> 
Sun Oct 29 18:51:15 2913 +9800 
hddqd b-txt9? 
DOm 6351ffE94541a6 if6f2cehblaachbh55ge2 
huthor: Wil1l 《xxxegmail.com> 
Sun Oct 29 18:51:15 209013 +09899 
Upqate Ba-txt9 
d6e5850h3ch 
Uil1l 《xxxegmail-com> 


Sun Oct 29 18:51:15 2913 +98909 


Initial commit 〈《a-txt cFeated? 


这 时 如 果 我 们 再 重新 执行 一 
次 djit revetrt 6351ff0 这 个 指令 试图 再 还 原 一 
次 ， 你 会 看 到 的 是 ' 合 伴 ， 失败 时 才 会 有 的 衢 突 情 


AAA。 


NS 


:Ngit-Fkeuert-demo>type aa-txt 


:Ngit-Feuert-demo>git Feuert 6351ffD 
ekkor: could not Feuert 6351fEfD..-。Update aa-txt9 
hint: after Phesoluing the conf1licts。makk the cokFected paths 
hint: with "9git add 《paths>” oF :9g9it Fm 《pathsy> 
hint: and commit the Fesult with 2g9it commit 


:Ngit-Fkevert-demo>type a-txt 
《<<<<(< 人 人 EnhD 


3 
>>>>>>> paFent of 6351ffD---。 Update Ba-txtg 


:Ngit-Fhevert-demo>git Qif 
一 -cc 已- 上 txt 
index d855592 .3?7hbhcc8hb- -909980009 


:Ngit-FeueFrt-demo >。 


发 生 本 次 种 突 的 原因 就 在 於 ， 我 们 想 逮 原 

的 6351ffo 这 个 版 本 ， 这 次 的 变更 原本 是 1 改 

成 2， 由 於 我 们 想 逮 原 内 容 ， 则 是 把 2 改 为 1, 但 
我 们 现在 的 内 容 和 邹 是 3 而 不 是 2， 央 而 发 生 了 衢 突 
状 沈 。 


所 以 这 种 ' 合 供 征 突 , 的 状况 ， 跟 我 们 之 前 在 【第 


17 天 : 关於 合 供 的 基本 观念 与 使 用 方式 】 如 出 一 
示 ， 解 决 的 方法 也 是 一 样 ， 你 可 以 选择 : 


1. 手动 编辑 a.txt 档案 ， 把 合 供 征 突 的 标示 给 移 
除 ， 编 辑 出 一 个 你 几 得 正确 的 内 容 。 

2. 使 用 SourceTree 工具 ， 自 行 园 出 一 个 你 想 要 
的 版 本 。 


如 果 你 寻 择 'Theirs' (他 的 ) 版 本 ， 就 代表 你 想 要 接 
受 6351ffo 的 版 本 : 


| git-revert-demo X 


5 Show Pending 
mc sd 
[ M 


? Filename Path 


Show in Explorer 
Copy Path To Clipboard 


External Di 许 


Remove 
Discard 


Stop Tracking 
Unstage from index 


Resolve Conflicts | Launch External Merge Tool 


Log Selected_ | Resolve Using 'Mine' 
Blame selected_ [Resoke Usine Theirs' 


Restart Merge 
Mark Resolved 


Mark Unresolved 


解决 备 突 后 ， 你 可 以 看 到 我 们 的 a.txt 内 容 已 经 继 
回 了 1 ,站 执 行 git_ commit 提交 这 次 版 本 释 


:Ngit-heuert-demo>type aa-txt 


:Ngit-Feuert-dqemo>git Status 
On branch master 
ou aFre cukrhent1ly keuekting commit 6351ffO- 
《all conf1licts fixed: kun "git Feuekht -continue "> 
《use "9git heueht -ahbort'" to cancel the Fevekht 0pekhation7> 


Changes to be committed: 
《use ""git keset HEhD 《file>.--"” to unstage? 


:Ngit-Feuert-demo>git commit 
[master 49e4f41] Revuert ' 咱 pdate Ba-txtg 
1 file changed。 1 insekhtionC+>。 1 deletion(K-)》 


一 样 在 执行 sit commit 会 跳出 让 你 编 
辑 commit 讯息 的 视窗 ， 这 壬 的 预 设 内 容 也 会 标示 
那些 档案 发 生 了 衢 突 : 


大 
Fille Edit View Settings 2 
D 营 马 电 | | % 生 岛 | 的 旺 和 @ 咏 | 国 双 | 
1 Revert “Update a.TxtI” 
2 
3 IThis_ reverts_Commit 6351ff04541a65b82df6f2ceblaacb550e2ea028 . 
级 
5 
6 
s 举 Please enter the commit message for Your changes. Lines starting 
3 沧 with “ 溯 ”will1 be ignored，and an empty message aborts the Commit . 


10 人 沧 On branch master 
11 举 YOou are current1y reverting commit 6351ff0. 
12 涯 (al1 conf1icts fixed: run "9git revert --cContinue ”) 
13 志 (use“git revert --abort”to cance]1 the revert operation) 
14 溯 
15 “人 ## Changes to be committed : 
16 并 (use “git reset HEAD <file>.. . 
江 
江 
涯 


to unstage) 
17 

18 
19 
20 


modified: a.EXt 


全 git 1log 的 内 容 和 与 最 近 一 次 的 释 更 内 
， 你 就 可 以 看 出 完整 的 版 本 变更 资讯 : 


git-Freuekrt-demo>git 1og -5 
49 4 工 上 2 78， 1 
huthor: Will 《xxxegmail-com> 
iDpate : Sun Oct 29 29:14:31 2913 +9869 


Revert '" 咱 pdate aa-txte 
This reuerts commit 6351ffB94541a65b82dqf6f2cehblaachbh55ge2eag28 . 


Conf licts: 
已 七 X 


huthor: Will 《xxxegmail.com> 
ipate : Sun Oct 29 19:58:19 2913 +9869 
Update a-txt to ?37 
Ommit ?aect dc8 8hb841 
huthor: Wil1l 《xxxegmail.-com> 
ipate : Sun Oct 29 19:109:17 2913 +9899 
Reuert '" 咱 pqdate aa-txte 


This reuerts commit 6351ffB94541a65b82dqf6f2cehblaachb55ge2eag28 . 


Will 《xxxegmail.com> 


Sun Oct 29 18:51:15 20913 +9809 
hdqd b-txt9 
1 于 于 日 41a65hb8 人 
Will 《xxxegmail.-com> 
ipate : Sun Oct 29 18:51:15 2913 +9800 
Updqate a-txt9? 
:Ngit-Feuekt-demo>git show 49e4f41 
49e4f41565af cy7?gea6l7107hbl 
Wil1l 《xxxegmail-com> 
Sun Oct 29 29:14:31 2913 +98969 
Reuvert ' 川 pdate 己 -txte 


This reuerts commit 6351ff094541a65hb82dqf6f2cehblaach55ge2eag28 . 


Conflicts : 
己 -tXt 


FE 一 -9it aa-txt ba-txt 
indqex dq855592. .37bcc8h 199644 


:Ngit-Feuert-demo > 


使 用 Git zevVeLt 命令 套用 继 更 但 不 执 
行 commit 动作 


人 git revert 时 ， 预 设 各 执行 成 功 ， 会 直接 建 
一 个 commit 版 本 ， 如 果 你 希望 在 执 

行 git revert 之 后 先 保留 伙 更 的 内 容 ， 也 许 再 汪 

加 一 些 档案 或 修改 一 些 内容 ， 然 后 再 自行 签 入 的 

话 ， 可 以 使 用 以 下 步 卫 。 


假设 这 次 我 们 想 膛 原 955cas9 这 个 版 本 ， 这 个 版 本 

其 实 是 新 增 一 个 b.txt 档案 而 已 ， 如 果 我 们 

用 sit show 955ca89 显示 其 弧 更 状况 ， 你 可 以 看 

人 --- /dev/null 其 实 就 是 代表 955ca89 
一 版 之 前 苑 没有 这 个 档案 ， 代 表 这 个 档案 是 在 这 

0 进来 的 ， 而 且 内 容 为 1。 这 也 代表 

著 ， 如 果 要 成 功 还原, (revert) 这 版 ， 目 前 

的 b.txt 内 容 必须 为 1， 然 后 才 会 成 功 执 行 “ 删 

除 , 的 动作 。 


Reuvert " 川 pdate 己 -Extg 
Upqate a-txt to ?3 
Reuert ' 川 pdate Ba-txtey 
haqdqd b.txt9 
Update a-txtg 
” Initial commit 《〈《a-txt ckheated) 


:Ngit-keuerkt-demo >9git 和 9355ca89 
mmit 9355 于 
huthor: WUil1l 《xxxegmail- ED 洒 


Sun Oct 29 18:51:15 20913 +0809 


hddqd hb. 上 txt9 


If 一 -9it ahb-txt bnhb .txt 
ew file mode 199644 
index 09060669 . .37hbhcc8h 


-- vdqeuvnu11 
+++ bb .txt 
a DB + Be 


:Ng9it-FeuePt-demo> 


现在 我 们 输入 sit revert -n 人 ,没有 提示 
任何 文字 ， 但 事实 上 b.txt 这 个 档案 已 经 成 功 被 删 
除了 ， 我 们 吉 行 git status II 


:Ngit-Feuerht-demo>gqit Show 955ca89 


ommit 5ca895dd3e93pbfd9f165f?7a9466b84f' 


huthor: WUill 《xxxegmail.com> 
IDate : Sun Oct 29 18:51:15 2013 +0800 


hdqd b-txt9? 


EE 一 -9it ab-txt bnhb-txt 
ew file mode 196644 
index 00060008. .37hbhcc8h 


:Ngit-FeueFt-demo>git Status 
性 On branch mastehk 
othing to commit。woFking directorkry clean 


:Ngit-Feuert-demo>gqit Fevert -n 955ca89 


:Ngit-Feuekt-demo>gqit Status 
性 On branch mastek 
性 ou ake cukFent1luy Feuekrting commit 955ca89 - 
《all conf1licts fixed: Fun "qit FeueFt 一 -continue "> 
《use "qit keuekt --ahbort" to cancel the FeueFht 0peFkation? 


性 Changes to be committed: 
《use "qit heset HEhD 《file>---”"”to unstage7? 


:Ngit-FeueFt-demo> 


这 个 时 候 ， 款 引 杖 感 已 经 被 更 新 ， 但 你 逮 是 可 以 继 
续 修 改 这 个 版 本 ， 直 到 你 想 完 成 本 次 动作 。 和 从 上 图 
你 可 以 看 到 你 有 两 个 执行 的 遗 项 ， 分 别 是 : 


1 9it revVett --cContinue 代表 你 已 经 完成 所 有 
操作 ， 于 且 建立 一 个 新 版 本 ， 就 跟 吉 
行 9it commit 一 样 。 


2. git revert --abort 代表 你 准 傅 放 课 过 次 复 


原 的 动作 ， 执 行 这 个 命令 会 让 所 有 释 更 状态 逮 
原 ， 也 就 是 删除 的 档案 又 会 被 加 回来 。 


ZX 二 呈 - 7 纪 


请 注意 : 浊 glit TevVert 一 mn 执行 完全 ， 壮 不 是 
用 sit commit 建立 版 本 喔 ! 


今日 小 短 


天 介绍 的 “ 还原, 版 本 的 机 制 ， 其 实 是 透 过 ' 新 
内 一 一 个 版 本 4 的 方式 把 变更 的 内 容 改 回来 ， 而 且 透 
过 这 种 方式 ， 你 可 以 透 过 版 本 历史 纪 和 从 中 明确 找 出 
人 另外 就 是 过 
个 “还原 , 的 过 程 ， 其 实 跟 ' 合 伴 , 的 过 程 非 常 类 
似 ， 发 生 种 突 时 的 解决 方法 也 都 如 出 一 才 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git show [commit_id] 
。git revert [commit_ id] 
。git revert [commit id] -n 


另外 还 有些 参数 没 介 绍 到 ， 建 议 可 


用 9it helpP revVetLt 查询 完整 用 法 : 


。git revert [commit_id] -s (在 讯息 内 容 加 上 目前 


使 用 者 的 签署 名 称 ) 
。git revert [commit_id] -e (在 完成 版 本 之 前 显示 
编辑 讯息 的 视窗 ) 


*。 HOME 


。 回 目 色 

。 前 一 天 : 设 定 .gitignore 忽略 清单 

。 下 一 天 : 修正 commit 过 的 版 本 帮 史 纪 杀 Part 
3 (cherry-pick) 


第 21 天 :修正 commit 过 的 
版 本 历史 纪 外 Part 3 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/21.md 


在 版 本 控 管 过 程 中 ， 还 有 个 常见 的 状况 ， 那 就 是 沼 
你 在 一 个 分 支 中 开发 了 一 段 时 间 ， 但 和 后 来 决定 整个 
分 支 都 不 要 了 ， 不 过 当中 抒 有 绑 个 版 本 还 想 留 下 
这 时 要 删除 分 支 也 不 是 ， 把 这 个 分 支 合 供 回 来 也 不 
是 ， 那 该 皇 庆 办 呢 ? 本 篇 文章 将 说 明 你 该 如 何 利 
用 sit cherry-pick 指令 ' 手动 挑 出 , 你 想 套 用 的 


入 和 
之 义 o 


准 们 本 日 练 避 用 的 版 本 库 


在 开始 说 明 前 ， 我 们 一 样 先 用 以 下 指令 建立 一 个 练 
习 用 的 工作 目 色 与 本 地 储存 库 。 文 章 看 到 这 壬 ， 想 
必 各 位 看 到 指令 应 该 都 知道 在 做 什么 事 了 吧 。 我 们 
在 一 开始 建立 2 个 版 本 后 ， 束 建立 了 一 个 pranchl 
分 广 ， 然 后 在 分 文 壬 建立 了 三 个 版 本 ， 其 中 一 个 版 


本 为 新 增 一 个 5.txt 档案。 最 后 我 们 再 切换 
回 master 分 支 ， 半 新 增 一 个 释 


二 基本 于 生 玉 癌 于 二 人 有 人 人 下 三 记 于 人 三 号 inie 


Sceneseehensy seKEaseme 
Qice maste 


全 GIRL EEDOE 
全 癌 


GEECOIEIOEm TREATED EECeaEEd) 


ELE 
he=iolel 
二 在 本 全 站 放 肌 了 下 王 二 人 枯 放任 


GineekKeREE 提 帅 oahmEhn 

SG EECE 

me Eielel 

可 汪 下 0 
Seho 有 提 天 之 国 加 辣 Ece 

likEaaa 


本 站 站 放 肌 相克 届 全 区 全 


SG 本 坟 攻 


人 TiEEaSOqO 
GEEConmnl 和 有 WUDaae ae LE LO 


9it checkout masteL 


Selnio 硬 > 


GEaaa 
全 工 二 GOmimn 王 三 站 出 “本 旬 轴 二 全 人 直属 


:Ngqit-cherry-pick-demo>git branch 
branchil 


:Ng9it-chekruy-pick-demo>gqit 1og 一 -one1line 
Upqate Ba-txt to 3 了 39 
Updqate 己 -txt to 29 
Initial commit 《a-txt ckheatedy) 


如 果 我 们 用 SourceTree 查看 储存 库 的 commit 
graph (版 本 线 图 ) 的 话 ， 可 以 看 到 如 下 图 蓝 色 的 部 
分 是 我 们 master 分 支 的 汽 化 ， 一 共 三 个 版 本 。 红 
色 是 branchl 的 分 支 ， 如 果 仅 以 这 个 分 支 来 看 也 有 
三 个 版 本 。 


git-chery-pick-demo X | 


4 File Status All Branches Y [Vshow Remote Branches ”Date Drder 
的 Working copy Graph 一 
4 Branches O Update abxtto 3! 
且 branchl Update atbxttto 41 
SP master Add bbxtt! 
Tags | Update atxtto 3! 
Remotes Update atxtto 21 


Initial commit (atxt created) 


使 用 Git cherzy-Pick 命令 的 ; 意 事项 


首 务 ， 你 的 :工作 目录 , 必须 是 乾 淆 ， 工 作 目录 下 

的 “ 乏 引 , 不 能 有 任何 准备 要 commit 的 档案 

(staged files) 在 里 面 ， 否 则 将 会 德 法 执行 。 

使 用 G9it ChezLzyYy-Pick 命令 

使 用 9it cherry-Pick 跟 使 用 dit zeVeLrt 非常 相 

似 ， 也 是 让 你 " 挑 于 ,任意 一 个 或 多 个 版 本 ， 然 后 

套用 在 目前 分 支 的 最 新 版 上 ， 但 主要 差 星 则 在 於 
sgit revert 执行 的 是 相反 的 合 儒 ， 

而 SI CeIEEy 一 PICK | 

更 , ， 但 一 样 都 是 透 过 ' 合 伴 , 的 方式 进行 ， 所 以 

本 篇 文章 我 不 会 做 太 多 类 似 的 相关 练习 ， 闪 

在 讲解 两 种 指令 上 的 差 虹 。 


证 : cherry-pick 的 英文 是 " 抢 樱 桃 : 的 意思 ， 代 


表 你 可 以 和 从 其 他 篮子 (分 文 ) " 挑 : 一 些 好 的 机 桃 到 
目 己 的 篮子 (分 文 ) 壬 ! 


各 位 在 使 用 sit 命令 时 
SourceTree 等 GUI 工具 ， 查 看 你 想 要 ' 挑 疆 ,出 
来 的 版 本 ， 然 后 套用 在 目前 的 分 支 上 (当然 是 套用 
在 目前 的 HEap 版 本 之 后 )。 


目前 我 们 位 於 master 分 支 上 知 要 查询 branchl 
的 所 有 纪 外 “， 我 们 执行 sit log branchl 即 可 (如 
下 图 加 上 -4 代表 众 显 示 前 4 笔 纪 凶 ) : 


:Ngit-cherrkry-pick-dqemo>9git branch 
branchil 


居 5 和 ane ee 一 4 
14b709529aa5ce43e0 
huthor: uil1 ai 二 
Mon Oct 21 18:20:32 2013 +0800 


Updqate aa-txt to 49 


?hbh4e650984653e3 


| 1 日 173c8QduB8， 
"二 Will 《xxxegmail.-com> 


Mon Oct 21 18:209:29 2013 +0800 
hb -txt 
mmit hdud4 

huthor: UVUil1l 《xxxegmail.comy> 

Mon Oct 21 18:209:099 20913 +0869 
Updqate a-txt to 39 
commit 38334f?7hbd5?73f46hbh43143c42d773fb9?61 
huthor: Wil1l1 《xxxegmail- 


IDate : Mon Oct 21 18:29:04 2013 +0800 


Updqate a-txt to 29 


今天 我 想 套 用 branchl 的 ac07017 add b.txtl 
个 版 本 到 目前 的 masteL 版 本 上 7 可 以 雪 
行 git_ cherry-pick dc07017 命令 ， 若 成 功 执 


行 ， 则 会 在 目前 的 master 分 支 建立 一 个 新 版 本 。 


:Ngit-cherry-pick-demo>gqit branch 
hbranchi 


:Ngit-cherry-pick-dqemo>git 1og 
ommit 3aga954a69dcdb8cd?7?95efeclf68ad8f8Bhb7f8D 


huthor: Vill 《xxxegmail.-com> 
Mon Oct 21 18:21:31 2013 +0800 


Updqate a-txt to 39 
ommit 38334f?7hd573f46h: 
huthor: WUil1l 《xxxegmail.com> 
Mon Oct 21 18:290:04 2013 +0800 
Updqate a-txt to 29 
hb4250951852ecef6l6g6l16aadc656et 
huthor: Vil1l 《xxxegmail.-com> 


Mon Oct 21 18:19:59 20913 +0809 


Initial commit 〈《a-txt cheated)? 


:Ngit-cherry-pDick-demo>gqit cherry-pick dcg7917 
[mastekr alhb9217?7] haqq hb.-txty 

1 file changed。 1 insektioncC+》 

ckeate mode 19099644 hb.txt 


:Ngit-cherry-Dick-demo>git 1og 
Commilt 二 b9217f8965: 712c413! 
"二 WUill 《xxxegmail.-com> 
Mon Oct 21 18:209:29 20913 +0809 


hddq hb-txte 


:Ngit-cherry-pick-qemo > 


不 过 7 熏 9jit evVeLtt 最 大 的 不 同 之 处 7 就 在 於 执 
完 SI 七 CheeseEY= 一 PICK 命令 和 合 其 建立 的 版 本 讯 


| 


息 ， 将 会 与 你 指定 挑 导 的 那些 版 本 一 模 一 样 ， 其 中 
包括 Author 与 Date 栏 位 ， 都 会 一 模 一 样 ， 焉 不 会 
用 你 在 选项 设 定 中 指定 的 user.name 

与 user.email 参数 。 这 点 你 必须 特别 注意 ! 


使 用 gGit chezzYy-Pick 命令 的 其 他 参数 


你 可 以 玩 择 加 上 -x 参数 在 指令 列 上 ， 就 会 
像 sit revezrt 那样 ， 自 动 加 
上 (cherry pickeqd from commit dc070173c8dq087b4e650 


的 讯 上 ， 如 下 图 示 : 


:Ngit-cherry-pDick-demo>git Feset -hard HEhD 1 
EhD is now at 3aga954 Update a-txt to 39 


:Ngit-cherry-pick-demo>git cherry-pick dcgB7917 一 x 
[master lce24ef] hdd b-txt? 

1 file changed。 1 insertionC+》 

create mode 199644 b-txt 


:Ngit-cherry-pick-demo>git 1og 于 


uthor : Wil1l 《xxx@gmail.com> 
Date: Mon Oct 21 18:209:29 2913 +D8D9 


hadd b-txt9 
《cherry pickedqd from commit dcgz769l173c8d687hb4e65084653e31hb819169f3f2e57> 


:Ngit-cherry-pick-demo> 


不 过 ， 做 这 个 动作 之 前 也 请 先 思考 ， 你 这 次 挑 玩 的 
版 本 是 不 是 只 有 本 地 才 有 的 分 文 : 上 挑 导 的 ， 如 
果 是 的 话 ， 这 样 的 纪 人 可 能 会 造成 其 他 人 的 混淆 ， 
因为 他 们 查 不 到 该 版 本 的 任何 资讯 。 这 在 使 用 带 端 
储存 库 的 情境 比较 会 碰 到 。 


如 果 和 希望 在 建立 版 本 前 先 编辑 讯息 ， 那 床 你 可 以 输 


入 dit cherry-Pick qdqc07017 -e 指令 。 


如 果 你 不 想 建 立 版 本 ， 仅 套用 其 释 更 ， 那 床 你 可 以 
执行 git cherzry-pick dc07017 -n 指令 ， 这 样 就 
不 会 自动 建立 版 本 ， 你 可 以 在 加 上 自己 的 修改 后 ， 
扣 行 git commit 建立 版 本 。 透 过 -n 参数 ， 这 次 
建立 的 版 本 就 会 留 下 自己 的 Author & Date 资讯 ! 


今 今日 小 颖 


今天 大 家 学 到 如 何 “〔 抢 机 桃 , 的 技巧 ， 不 过 我 没 闪 
法 教 你 "怎样 挑 出 好 的 樱桃 , ， 这 就 要 问 你 自己 才 
知道 了 ! :-) 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git cherry-pick [commit id] 

。git cherry-pick [commit id] -e 
。 git cherry-pick [commit_ id] -x 
。git cherry-pick [commit_ id] -n 


。 HOME 
。 回 目 色 


。 前 一 天 : 修正 commit 过 的 版 本 历史 纪 杀 Part 
2 (revet) 

。 下 一 天 : 修正 commit 过 的 版 本 帮 史 纪 杀 Part 
4 (rebase) 


第 22 天 :修正 commit 过 的 
版 本 历史 纪 色 Part 4 
(Rebase) 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/22.md 


我 们 之 前 已 经 讲 了 三 种 不 同 的 修正 版 本 的 方法 ， 感 
格 上 来 说 git revert 盟 git cherry-pick 普 不 算 
修正 版 本 历史 纪 休 ，， 而 是 套用 先前 曾经 commit 
过 的 版 本 ， 看 是 "重新 套用 , 或 '“ 反 向 套用 , 的 差 
别 而 已 。 本 篇 文章 将 要 来 说 明 Git 中 的 Rebase 机 
制 ， 这 个 所 谓 的 Rebase 机 制 就 是 真 的 用 来 修改 
commit 纪 针 的 功能 了 ， 其 功能 重要 而 且 强 大 。 


准 全 本 日 练 避 用 的 版 本 库 


我 们 一 榜 先 用 以 下 指令 建立 一 个 练 普 用 的 工作 目 针 
与 本 地 储存 库 (一 样 先 切 换 到 c:\ 然后 复 揣 贴 上 就 
会 自动 建立 完成 ) : 


mkdqir 9it-zrebase-dqemo 


cq dgit-trebase-dqemo 


RE ARE 


CCTVOT > 是 ErAE 
9it adqd 


QQ) " 


TIG 人 2 人 OO 着 


Goe2 症 之 和 3 本 蕊 光世 
Ga 二 seq 
本 放 了 全 疙 而 帮主 二 交 用 册 和 村 


NT 


建立 站 切换 到 branchl 分 支 


GuieeenmscekouEe = 二 oamCRi 


客人 
aieaoq 
Gecemmaieee mdo 基 所 瑟 ee 


te 
GE 本 gd 
GeeeeOmmieee mA 本 e 过 必 文 长 史 


Sehho 醒 3 已 年 本 已 
EREE ELE 人 人 | 
GE 本 Cemmaieesmauyi2oat < 芋 C 且 攻关 已 汪 O 汪 8 志 汉 这 


SCnhenag > OO 站 
peEiolel 
Geecipe AcelocREE 


ODN OUREEO 攻 LI 


切换 到 mastezr 分 支 


9it checkout masteL 


ECcnon ”> EX 
GeEielel 
Geece EUSCESIESRESREOEEGD 3: 


我 们 用 SourceTree 查看 储存 库 的 commit graph 
(版 本 线 图 ) 如 下 : 


git-rebase-demo X 


4 File Status All Branches Y Show Remote Branches ”Date Order v 
@worirgcpy aa 一 
4 Branches 


吸 branchl 
master Update ctbxtto 333 
Tags ES 
Remotes Add bbd 
昌 Update a.bxdtto 2 


Initial commit (atbxt created) 


使 用 sit rebase 命令 的 注意 事项 


首先 ， 你 的 “工作 目 杀 , 必须 是 乾 泽 ， 工 作 目 销 下 
的 “索引 不 能 有 任何 准备 要 commit 的 档案 
(staged files) 在 壬 面 ， 否 则 将 会 乱 法 执行 。 


ot Fehbase: Youk index contai 
commit ok Stash the 


ncommitted changes -. 


再 来 ， 也 是 最 重要 的 ， 如 果 你 的 分 文 是 从 玉 端 储存 
库 下 载 回来 的 ， 请 干 万 不 要 通过 Rebase 修改 版 本 
历史 纪 和 从 ， 否 则 你 将 会 乱 法 将 修改 过 和 后 的 版 本 送 到 
运 端 储存 库 ! 


Rebase 是 什么 ? 


Rebase 是 "Re-" 与 "Base" 的 复合 字 ， 这 壬 的 
"Base" 代表 上 基础 版 本 , 的 意思 ， 表 示 你 想 要 重新 
修改 特定 分 支 的 “基础 版 本 ， ， 把 另外 一 个 分 支 的 
变更 ， 沼 成 我 这 个 分 支 的 基础 。 


我 们 现在 就 来 做 一 个 简单 的 Rebase 示范 ， 我 们 大 
概 做 禾 件 事 : 


1. 切换 至 Dranchl 分 


9it checkout branchl 


2. 然后 执行 Rebase 动作 ， 把 master 当成 我 们 
的 基础 HI 反 本 : 9it rebase masteL 


CANW 


:Ngit-Fkehbase-demo>git branch 
branchil 


:Ngit-Fehbase-demo>git checkout hbranchi 
朴 witched to branch "branchil” 


:Ngit-Fkehbase-demo>gqit Fehbhase mastekr 
IFirst。Fewinding head to FepDplavy youFk wokk on top of it--- 
: hdqdqd hb-txt 
: hdq c -上 txt 
: Update c-txt to 333 
hpplving: hdd dtxt 


:Ngit-Fehbase-demo> 


请 注意 执行 完 ait rebase mastezr 之 人 后 的 显示 讯 
息 ， 他 褒 先 将 我 们 branchl 分 支 的 最 新 版 本 (head) 
倒 带 (rewind) 到 跟 master 一 样 的 分 支 起 点 
(rewinding head)， 然 后 再 重新 套用 (replay) 指 定 

的 mastez 分 支 中 所 有 版 本 。 喘 文 的 on top of it 
代表 的 是 让 branchl 分 支 原 本 的 变更 套用 

在 master 上 面 ， 所 谓 的 上面, 代表 的 是 先 套 
用 master 的 版 本 / 然后 才 套 用 DIEanchlI 的 版 本 
(请 见 上 图 的 Applying: 那 做 行 )。 


我 们 看 看 套用 完 之 后 从 SourceTree 看 到 的 版 本 线 
图 (commit graph)， 你 看 看 这 是 不 是 很 神奇 ， 版 本 
线 图 变 成 一 直线 了 : 


git-rebase-demo 


4 File Status All Branches Show Remote Branches 。” Date Order * 
办 Workingcopy 上 Graph 
4 Branches [ 壁 eranchijAdd dbdt 
(从 branch1 Update ctxtto 333 
叶 master Add cbt 
Tags Add b-bt 
0 ET Updateatbtto 3 


Update atbxtto2 
Initial commit (atxt created) 


各 位 看 官 ， 看 到 上 面 的 版 本 线 图 ， 你 会 不 会 觉得 
[分支 , 的 感 恤 不 见 了 呢 ? 事实 上 ， 分 支 东 没有 改 
弧 ， 而 是 这 继 个 版 本 的 “套用 顺序 , 被 修改 了 。 目 
前 这 张 图 所 代表 的 意思 ,就 如 同 以 下 指令 的 执行 顺 
序 : 


1. 建立 Initial commit (a.txt created)， 同 时 预 设 
建立 masS 七 eL 分 文 

2. 建立 Update a.txt to 2 

3. 建立 Update a.txtto 3 

4. 建立 下 切换 至 branchl 分 支 

5. 然后 不 断 commit 到 Add d.txt 这 个 版 本 


所 以 ， 这 其 实 逮 是 ' 两 个 分 支 , 喔 ， 冰 没 有 被 合 供 
成 一 个 ! 干 万 别 认为 这 张 图 只 有 一 条 线 ， 所 以 只 
一 个 分 交 。 


有 分 支 ， 就 有 合 伴 ， 现 在 的 你 ， 如果 想 要 


把 DanchTI 的 释 更 7 套用 到 masteL 分 支 上 在 使 
用 过 Rebase 之 后 ， 你 会 有 两 种 合 人 的 方式 : 


1. 透 过 一 般 合 供 指 令 ， 芷 触发 Git 的 快 塌 机 制 
(Fast-forward) 


先 切 换 到 master 分 支 ， 然 后 直接 执 

行 git merge branchl1 ， 这 时 会 引发 Git 的 快 转 机 
制 (Fast-forward)。 所 谓 的 “ 快 转 机制 ， ， 就 是 Git 
得 知 这 个 合 供 的 过 程 ， 其 实 会 依 序 套用 branchl 原 
本 就 有 的 变更 ， 所 以 在 合 供 的 时 候 会 直接 修 

改 master 分 支 的 HEap 参照 绝对 名 称 ， 直 接 移 动 
到 branchl 的 Hgap 那个 版 本 。 


:Ngit-hehbhase-demo>git branch 


mastek 


:Ngqit-hehbhase-demo>git checkout mastekr 
朴 witched to branch mastek” 


:Ngqit-hehbase-demo>gqit mekgqe hbranchil 

pdating 4d76917.- .3fahbbb4 
IFast-forward 

btxt 上 工 

C-txt 上 工 

Qtxt 上 工 

3 files changed。 3 insekhtions(K+7? 

ckeate mode 109009644 hb .txt 

ckeate mode 1009644 c -txt 

ckeate mode 1009644 Qtxt 


: Ngit-Pehbase--dqemoy> 


最 后 我 们 得 到 的 线 图 冰 是 一 直线 ， 但 你 可 以 看 


到 mastez 的 分 支 已 经 移动 到 跟 branchl 一 样 了 。 


如 下 图 示 : 


git-rebase-demo X 


4 File Status All Branches V] show Remete 6ranches 。” Date Drder 
Workng Cocpy Graph 
4 Branches O 区 masten|[ 过 branchi]jAdd dbxt 
branchi 局 Update ctxtto 333 
master 撮 Add ctxt 
Tags 外 Add bbt 
Remotes 伸 
提 Update atxtto 2 
息 Initial commit (atyxt created) 


2. 透 过 --no-ff 参数 ， 停 用 Git 的 快 转 机 制 


先 切 换 到 master 分 支 ， 然 后 直接 执 


行 9it merde branchl 一 -no 一 开工 即 吕 。 


:Ngit-Fhehbase-demo>git heset 一 -hakdqd HEhNDBG<IL> 
EhD is now at 4dqz76917 Update a-txt to 3 


:Ngit-hehbhase-demo>gqit branch 
hbranchil 


:Ngit-Pehbase-demo>git mekgqe hbranchli 一 -no 一 上 工 
ekFkgqe made buv the "hecukhsiue” sthategv- 
JEXE 人 

C-txt 1 工 

Qtxt 1 工 

3 files changed。 3 inseFktionsdK+y? 

Chkeate mode 10909644 hb .txt 

chkeate mode 109644 c -txt 

chkeate mode 109644 Qtxt 


当 你 合 供 时 指定 停 用 Git 的 快 转 机 制 ， 那 就 代表 
不 允许 快 转 , 的 意思 。 也 代表 著 ， 他 会 
算 合 供 的 那个 branchl 先 建立 一 个 分 支 ， 然 后 最 后 
再 合 儒 回 master ， 人 

了 branchil 的 版 本 线 图 。 最 终 ， 你 看 到 的 版 本 线 图 
应 该 会 长 成 以 下 这 个 样子 ， 不 是 比 刚刚 一 直线 的 版 
本 线 图 还 漂亮 呢 ! :-) 


git-rebase-demo X 


4 File Status 1 Branches v Ye show Remaote Branches Date Order v 
的 Wiorking Copy 靖 Graph 和 
4 Branches 可 区 master| Mergebranch 'branch1' 
且 branchl | @ Add dbxt 
master 外 Updates ctxtto 333 
Tags | 龟 Add cbt 
Remotes 外 Add bbdt 


Update atxtto 3 
Updates atbxrtto 2 
Initial commit (atxt crsated) 


最 人 后， 如 果 你 的 branchl 用 不 到 的 话 ， 就 可 以 把 这 


个 分 支 给 删除 : 9it branch -Qq branch1l 


:Ngit-hehbase-demo>git brkranch 
branchi 


:Ng9it-hehbase-demo>git branch -QQ branchi 


Deleted branch branchl 《was 3fabhbhb4>-. 


:Ng9it-Phehbhase-demo>gqit brkranch 


:Ng9it-kehbhase-dqemo>。 


最 终 我 们 的 版 本 线 图 如 下 : 


git-rebase-demo X 


4 File Status All Branches Y Show Remaote Branches Date Order 
办 wWerkingcepy 上 RE 
4 Branches Merge branch 'branchf1' 
任 master Add dtbt 
Tags Update ctxtto 333 
Remotas Add cbxt 
Add bbxt 
Update atxtto 2 
Initial commit (atxt created) 


我 们 来 比 对 一 下 ， 如 果 用 我 们 最 刚 开 始 的 建立 的 初 
始 版 本 进行 合 供 的 话 ， 线 图 会 长 得 像 以 下 这 样 。 各 

位 有 没有 发 现 ， 我 们 原本 的 branchl 是 从 二 
atxt to 2 这 一 版 开始 分 支 的 ， 经 过 我 们 透 

Rebase 之 后 ， 分 支 的 起 点 不 太一 样 了 ， RE 


Update a.txt to 3 这 个 分 支 开 始 ， 是 不 是 很 有 趣 
听 ! 


git-rebase-demo X 


4 File Status All Branches Y ” [M show Remote Branches ”Dateorder v 
Working Copy 
4 Branches 
县 branchl 
只 master 
Tags Update ctbxtto 333 
Remotes Add ctbt 
Add b bt 
Update atxtto 2 
Initial commit (atxt created) 
人 公 、 日 | 士 
今日 小 颖 
第 


次 接触 Rebase 的 人 ， 或 许 会 荔 得 很 抽象 ， 各 


位 必须 细心 品味 ， 才 能 真正 感受 到 Rebase 带 来 的 
强大 威力 。 之 后 的 文章 壬 ， 我 迁 会 更 加 详细 的 介绍 
Rebase 的 进 障 用 法 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git rebase master 
。git merge branch1 
git branch -d branch1 


。 HOME 

。 回 目录 

前 一 天 : 修正 commit 过 的 版 本 历史 纪 杀 Part 
3 (cherry-pick) 


下 一 天 : 修正 commit 过 的 版 本 历史 纪 杀 Part 


5 (rebase 2) 


第 23 天 : 修正 commit 过 的 
版 本 历史 纪 外 Part 5 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/23.md 


我 们 上 一 篇 文章 谈 到 的 Rebase 是 用 来 将 现 有 的 两 
个 分 支 进行 " 重新 指定 基础 摄 本， ， 执 行 Rebase 
之 和 后， 也 会 改 掉 原本 分 支 的 起 点 (分 支 时 移 动 了 ) ， 
所 以 导致 版 本 线 图 发 生 释 化 。 不 过 Rebase 可 以 做 
到 的 能 力 不 只 这 样 ， 他 还 能 用 来 修改 特定 分 支线 上 
任何 一 个 版 本 的 版 本 资讯。 


准 位 本 日 练 避 用 的 版 本 库 


我 们 一 样 先 用 以 下 指令 建立 一 个 练 普 用 的 工作 目 针 
与 本 地 储存 库 (一 样 先 切 换 到 c:\ 然后 复 揣 贴 上 就 
会 自动 建立 完成 ) : 


mkadir g9it-zrebase-dqemo 


cq dg9it-trebase-dqemo 


RE 


SN 二 ECE 
二 人 忆 


GEEeCOIE ET OOQ) 


Rn 各 且 OO 


人 GoS2 
asaa 
GT 三 二 扩 有 本 人 二 


人 天 


建立 站 切换 到 branchl 分 支 


geneekeaE 所 量 区 aiEh 亚 


全 人 站 二 文 上 
peEelel 
GEEGCiieUEEESCooREDOEY 


Slot 
meEielel 
DEROcihnoa heleieE4EY 


Eee 要 3S 忆 思量 过 于 全 本 上 广 臣 
9it adqd 


GaseEcommanee maoae 王 CEO 世 3 


人 Ge OO 二 文 让 
GE 
neaereiniooannSAeleeREeea 


TERM 为 生 2I 训 吕 


: : 切换 到 master 分 支 


9it checkout masteL 


二 本 由 en 
GaOo 
Eeemmaiemauyeoaee 下 aa 王 Ex S 


证 : 上 述 指令 中 的 ping 127.0.0.1 -n 2 >nul 主 
要 是 用 到 了 如 何在 批 次 档 (Batch) 中 实现 sleep 命令 
让 任务 暂停 执行 n 秒 文章 中 提 到 的 技巧 。 


我 们 用 Source Tree 查看 储存 库 的 commit graph 
(版 本 线 图 ) 如 下 : 


git-rebase-demo X 


4 File Status | All Branches Y  [ 思 Show Remote Branches Date Order 
罗 workngcopy Graph 
4 Branches Update atxt to 3 


且 branchl Add db 
? master Update ctxtto 333 
Tags Add cbt 
Remotes Add bt 


Update atxtto 2 
Initial commit (atbxt created) 


使 用 git zebase 命令 的 注意 事项 


这 件 事 还 是 必须 重申 一 次 ! 首先 ， 你 的 “工作 目 
外 , 必须 是 乾 兆 ， 工 作 目 杀 下 的 “索引 不 能 有 任 
何 淮 人 备 要 commit 的 档案 (staged files) 在 里 面 ， 否 
则 指令 将 会 乱 法 执行 。 


:Ngit-Fehbase-demo>git kehbase e663e52 一 L 
annot Fehbase: Youh index contalins uncommitted changes - 


已 Ilease commit ok Stash them- 


再 来 ， 也 是 最 重要 的 ， 如 果 你 的 分 文 是 从 玉 端 储存 
库 下 载 回来 的 ， 请 千 万 个 要 通过 Rebase 修改 版 本 
历史 纪 休 ， 否 则 你 将 会 危 法 将 修改 过 和 后 的 版 本 送 到 
这 端 储存 麻 ! 


Rebase 能 做 的 事 


上 一 篇 文章 讲 的 ， 你 可 以 将 某 仙 分 支 当成 自己 目前 
分 支 的 “基础 版 本 ， 。 除 了 这 件 事 以 外 ， 你 膛 可 以 


用 来 修改 某 个 分 文中 ' 特定 一 段 ， 压 程 的 纪 人 录 ， 你 
可 以 做 的 事情 包括 : 


1. 调换 commit 的 顺序 

2. 修改 commit 的 讯息 

3. 插入 一 个 commit 

4. 编辑 一 个 commit 

5. 拆 解 一 个 commit 

6. 压缩 一 个 commit,， 且 保留 讯息 纪 杀 
7. 压缩 一 个 commit， 但 于 课 版 本 纪 销 
8. 删除 一 个 commit 


这 八 件 事 ， 可 以 完整 看 出 Rebase 修正 奈 史 版 本 纪 
人 的 强大 威力 ， 接 下 来 我 们 就 逐一 介绍 如 何 好 好 利 
用 Rebase 攻 我 们 修订 和 版 本 。 


1. 调换 commit 的 顺序 


首先 ， 我 们 先 切 换 到 branchl 分 支 


人 9it checkotut branchl ) 


:N9it-hehbase-demo>gqit branch 
branchi 


: Ngit-Fkehbase-demo>gqit checkout branchil 


Switchead to branch :branchi'” 
:NM9it-hehbase-demo>git branch 


masS 上 teh 


到 SourceTree 查看 版 本 线 图 ， 然 后 我 们 先决 定 这 
个 分 支 中 想 要 执行 Rebase 的 起 点 (不 一 定 要 是 分 
广 的 起 始点 ， 任 何 一 版 都 可 以 )， 决 定之 和 后， 直接 在 
SourceTree 复 拒 该 版 本 的 绝对 名 称 ( 也 就 是 以 
SHA1 杂 汉 过 的 Git 物件 ID)。 和 从 下 图 你 可 以 看 到 ， 
我 们 先 在 该 版 本 按 下 滑 鼠 右键 ， 然 后 再 点 选 Copy 
SHAto Clipboard 即 可 将 id 复 拒 到 甬 贴 水 中 : 


All Branches Y  IM shcw Remcte Branches Date Crder 、 
Graph 
Update atxtto 3 
o [ 宪 eano]Adddbd 
口 Update ctxtto 333 
〇 dd ctoxt 
曲 Add btxt 


Update atxtto 2 和 二 55 
Initial commit (atbxt Checkout.- 
Merge.. 


Rebase... 

Tag.… 

Branch... 

Reset current branch to this commit 
Reverse commit... 


Chenry Pick 


2 TECN 


然后 我 们 吉 


和 rebase 92f937al90elfca839eedq4f51dq7f7199b617 


主意 : 这 壬 
本 92f937a190elfca839eed4f51dq7f7199b617e3d4 


跟 你 自己 建立 的 可 能 不 一 样 ， 请 不 要 照抄 。 


接著 会 跳出 编辑 器 ， 胱 且 让 你 编辑 一 系列 “ 指 
令 ， 如 下 贺 示 : 


pick |d86532d Add b.txt 
pick |22el1885 Add c.tXTt 
pick |bf40bzc Update c.txXt tO 333 
pick |5027152 Add d.txt 


产 Rebase 92f937a. . 5027152 OntO 92f937a 


池 | Commands : 
六 ，pick = use commit 
rr，reword = use Commit，but edit the commit message 
，edit = Use commit，but stop for amending 
，5quash = Use commit，but meld into previous commit 
，fixup = 1ike “squash"，but discard this commit 5 109g message 


，exec = _ run command 《the rest of the 1ine) using she11 


If you remove a 1ine here THAT COMMIT WILL BE LOST. 


溯 
尖 
尖 
作 
尖 
人 These 1ines can be re-ordered; they are executed from top tO bottom. 
尖 
才 
才 
孝 However ，jif you remove everything，the rebase wi11 be aborted. 

才 

才 


Note that empty commits are Commented OU 


你 如 果 什 么 都 不 改 ， 就 是 执行 这 一 系列 pick 等 动 
作 ， 这 和 里 必须 先 让 各 位 瞳 解 的 是 这 些 指 令 的 格式 ， 
与 他 的 顺利 代表 的 意义 。 


我 们 先 来 看 第 一 行 ， 区 分 成 三 个 桐 位 ， 分 别 以 空 
白 子 元 间隔， 分 别 如 下 : 


一 人 


.pick 代表 的 是 上 命令 ， ， 底 下 广 解 的 部 分 有 一 
系列 上 命令 , 的 名 称 与 简写 ， 你 写 p 与 pick 
都 是 一 样 的 意思 。 

2. d86532d 代表 的 是 要 使 用 的 commit 物件 编号 

(绝对 名 称 )。 
3. 剩 下 的 文字 则 是 这 个 版 本 的 纪 杀 讯 息 摘 要 。 


如 果 你 有 看 过 【第 22 天 : 修正 commit 过 的 版 本 
历史 纪 杀 Part 4】 这 篇 文章 ， 你 应 该 会 知道 执行 
Rebase 的 时 候 ， 会 先 将 我 们 目前 branchl 分 支 的 
最 新 版 本 (head) 倒 带 (rewind) 到 你 这 次 指定 的 分 支 起 
点 (rewinding head)， 在 这 个 例子 里 ， 我 们 指定 的 分 
支 起 点 就 

是 92f937al90elfca839eed4f51d7f7199b617e3d4 
这 个 节点。 


这 时 我 们 用 sit 1log 查看 一 下 目前 的 版 本 纪 凶 ， 我 
们 指定 的 那个 版 本 ， 冰 不 在 我 们 的 Rebase 指令 清 
单 中 。 该 指令 清和 单 ， 由 上 至 下 分 别 是 最 备 版 , 到 
最 新 版 , 的 顺序 ， 跟 我 们 用 sit 1os 执行 的 题 示 
顺序 刚好 相反 : 


:Ng9it-hkehbhase-demo>git 1og 

ommit 50927?7152c3481a62aa4562530946fedf8du209383phf7 
huthor: Wil11 《xxxegmail-com> 
IDpate : Tue Oct 22 14:22:33 2013 +0800 


hadqdq Q .txt 
commit bf49hb2cagace748903290efh8?7c23?7d7?f3h41a6l 
huthor: Wil1 《xxxegmail.com> 


IDpate : Tue Oct 22 14:22:33 2013 +09809 


Updqate c-txt to 333 
Commit 22 6du9446ahbcfdldu284953hbh3hb6gBcodu699f39 
huthor: Wil1 《xxxegmail-com> 
Ipate : Tue Oct 22 14:22:33 2013 +0800 

hadd c -七 xt 
commit d86532dhbaeeahb?9411c2a8f3?79c794qdB6f38” 
huthor: Wil1 《xxxegmail-com> 


IDpate : Tue Oct 22 14:22:33 2013 +0800 


hdqd hb .txt 


ommit 2932f937al9pelfca839eedd4f5ld2f?199hbh6l7e3d4 
huthor: Wil1 《xxxegmail.com> 
IDpate : Tue Oct 22 14:22:32 2013 +09800 


Updqate a-txt to 2 
ommit eb663e52cb6a642ff5pbf391d9chb3f86988 
huthor: WUil1 《xxxegmail.com> 


IDpate : Tue Oct 22 14:22:31 2013 +0800 


Initial commit 《a-txt ckheated> 


我 们 再 重 看 一 次 这 绑 个 版 本 如 下 : 


Erekeele6sS2eEA weioREx 
Tek2ZEhSSS Ad CE 


one 人 lio2eUeieEWeSEeEEAe Co 
Re 区划 了 证 汪 iE< 


这 里 的 六 二 攻 攻 代表 的 功能 是 Use commit ， 也 就 是 我 
们 要 用 这 个 版 本 来 commit 新 版 本 。 也 就 是 上 一 篇 

文章 讲 到 的 重新 套用 (replay) 这 个 字 ， 所 以 这 继 个 指 
令 ， 就 是 让 你 在 分 支 " 倒 带 ,， 之后， 重新 用 这 类 个 

版 本 套用 一 次 版 本 变更 ， 而 且 重 新 套用 的 过 程 会 治 
用 当时 版 本 的 变更 纪 凶 。 


现在 我 们 先 来 当 试 "调换 commit 的 顺序 , 这 个 命 


从、 
Yo 


若 要 完成 【调换 commit 的 顺序 , 的 任务 ， 你 只 要 
很 简单 的 修改 这 份 文 字 档 ， 把 版 本 的 前 后 顺序 对 调 
即 可 ， 例 如 我 们 修改 成 : 


已 贡 GE 有 人 天 8 与 生态 过 蕊 区 忆 
one Eee 
EeeUBdaEecCRexeEeO 本 39 总 
Res 区 惠风 国 攻 卫 1E>< 


然后 存档 退出 ， 我 们 看 看 指令 最 后 的 执行 结果 篇 


一 


瑟 |MNA 


何 ， 你 5 
了 : 


页 序 对 调 


一 一 


:Ngit-hehbase-demo>git Fehbase 92f93?7al9gelfca839eed4f51ldz?7f?199hb61ly?7e3d4 一 
uccessfully rehbased and updated Fefs-heads-hbranchl - 


人 Fehbase 一 和 log 


二 ilL1l 《xxxBgmail。 Comy> 
Date : Tue Oct 22 14:22:33 2913 


hdd Qtxt 
83d87 
uthoF : Will 《xxxBegmail-comy> 
Tue Oct 22 14:22:33 2913 + 
Update c-txt to 333 
t | 7el 
"二 Will 《xxxegmail.-com> 


Tue Oct 22 14:22:33 2913 


hb -txt 


{t 4 f | 
"二 则 i11 《xxxegmail.-com> 
Tue 0ct 22 14:22:33 2913 


C -tx 


"二 Will 《xxxegmail.-com> 
Tue Oct 22 14:22:32 2913 


Update a-txt to 2 


这 和 里 有 一 点 你 必须 特别 注意 ， 那 就 是 

和 从 92f937al90elfca839eedq4f51dq7f7199b617e3d4 
这 个 版 本 开始 ， 所 有 和 后续 版 本 的 commit 绝对 名 称 
全 部 都 不 一 榜 了 ， 这 代表 我 们 在 Rebase 的 过 程 会 
重新 建立 许多 新 的 commit 物件 。 那 床 蓝 的 物件 到 
哪 壬 去 了 呢 ? 真相 是 ， 这 些 以 前 的 版 本 全 部 都 逮 
在 ， 只 是 你 找 不 到 圳 了 ， 全 都 躺 在 Git 物件 储存 库 
中 ， 只 要 你 知道 这 些 版 本 (也 就 是 commit 物件 ) 的 绝 
对 名 称 ， 你 就 可 以 随时 取出 ! (请 回 惰 一 


下 9it reflod 命令 ) 


我 们 从 SourceTree 壬 面 看 一 下 版 本 线 图 ， 感 汉 上 
跟 上 面 那 张 图 好 像 差 很 多 ， 但 其 实 只 有 这 两 个 版 本 
调换 而 已 ， 线 图 不 太一 样 的 原因 是 时 间 序 改 继 了 ， 
我 想 这 应 该 是 SourceTree 的 显示 逮 辑 跟 时 间 序 有 
关 ， 才 会 让 这 线 图 变 得 跟 之 前 差 这 氏 多， 初学 者 可 
别 弄 融 了 。 


git-rebase-demo X 


4 File Status All Branches Y Show Remote Branches Date Order v 
人 Working Copy Graph 
4 Branches Add d.tbxt 
寥 branch1 Update ctbxtto 333 
只 master 
Tags 
Remotes Updateatbtto3 


Update atbxtto 2 
Initial commit [atbxt created) 


1. 修改 commit 的 讯息 


修改 曾经 commit 过 的 讯息 ， 只 要 稍 加 修改 Rebase 


的 命令 即 可 ， 我 们 先 看 看 目前 的 版 本 纪 色 : 


:Ngit-Phehbase-demo>git 1og 
bed38fefyceb2d4coddfbbofd 
WUil1l <xxxegmail-comy> 
Tue Oct 22 14:22:33 2013 +09800 


Q -txXt 
d87?79a69fdf25f537c73dl4eg9441 


UWUil1l <xxxegmail.com> 
Tue Oct 22 14:22:33 2013 +0800 


Update c-txt to 333 


Commit 0341095683fbefb2f730097ellfy7d4ecftg9d 
huthor: Vi1l11 《xxxegmail-com> 
Tue Oct 22 14:22:33 2013 +0800 
pb .tx 
654a56fae4h311894d6a5255hbhaed9097dugdl99a6 
huthor: UVUi1lL1 《xxxegmail-com> 
Tue Oct 22 14:22:33 2013 +0800 
C -七 X 七 
92f937al9gelfca839eed4f51d7 
huthor: Vil11 《xxxegmail-com> 
Date : Tue Oct 22 14:22:32 2013 +09800 


Update a-txt to 2 


Commit ebb3e52cbab4ff5pbf391d9chb3fbb988 


huthor: UVUi1l11 《xxxegmail-com> 
Date : Tue Oct 22 14:22:31 2013 +0800 


Initial commit 《a-txt ckeatedy> 


如 果 我 们 打算 把 下 图 标示 红线 的 版 本 讯息 修改 
为 Update: c.txt 1Is changed to 333 文字 的 


话 ， 我 们 先 执 行 跟 上 个 例子 相同 的 指令 : 


9it rebase 92f937al90elfca839eedq4f51dq7f7195b617e 


然后 会 开 族 文字 编辑 器 ， 此 时 的 内 容 应 该 如 下 : 


DIECKES654a50 ANAadc 有 EX 
GE 全 6 攻 六 ga 重 刘 本 xx 
aek 是 65 UbbaaieecRieRE OO 已 志 
apel< 天 6 G 必 攻 AoielEeEIESRE 


我 们 想 修 改 6883da87 这 个 版 本 的 讯息 ， 只 要 把 这 一 
行 前 面 的 pick 改 成 reword 即 可 。 修 改 完 和 后 的 文 
子 如 下 : 


oneleESGS ES RRANoloEe ED 
JaneGEOSAROSGAeORLES<E 
下 3 
ee6edeSEAaaaq ER 


然后 存档 退出 ， 接 著 Git 会 开始 重新 pick 这 些 版 
本 进行 套用 7 但 套用 到 zewWord 这 个 命令 时 7 会 重 
新 再 开 艇 一 次 文字 编辑 器 ， 让 你 可 以 在 此 时 释 更 版 


本 讯息 文字 ， 这 时 我 们 直接 改 
成 Update: c.txt is changed to 333 文字 和 后 存 


档 退 出 ， 接 著 就 会 直接 套用 完 合 续 的 版 本 。 
RE 


Pile Edit View Settings 2 


Update: c.txt is changed to 33 j 


工 

2 

3 ## Please enter the commit message for your changes. Lines 
4 # with “#' will be ignored，and an empty message aborts 飞 
5  # HEAD detached from 0341056 

5 #You are currently editing a commit while rebasing branc 
TAR 

8 # Changes to be committed: 

(use “9git reset HEADAL <file>... ”to unstage) 


江 

人 才 
## modified: 丰 - 生 %E 
江 


我 们 最 后 再 用 sit 1og 查看 版 本 纪 休 “， 发 现 该 版 本 
的 讯息 确实 已 经 继 更 为 我 们 修改 的 那 段 文字 。 而 且 


该 版 本 和 与 后 纺 的 版 本 commit 物件 编号 也 会 不 一 
样 ， 不 一 样 代表 这 两 仙 是 新 的 commit 物件 。 


:Ngit-Febase-dqemo>git kehbase 92f937al9g9elfca839eed4f5ldz?f?199hb6ly7e3d4 一 
[detached HEhD a9eca?79] Update: c-txt is changed to 333 

1 file changed-。 1 insertionCG+?。 1 deletion(-)> 
Successfully kehbased and updated Fefsheads-hbranchl - 


:Ngit-Fehbase-dqemo>git 1og 
cclhbheegfggeltieat 
uthor: Will 《xxxegmail.com> 
pate: Tue 0ct 22 14:22:33 2013 +9809 
hdq Qtxt 
ommit 9 ?hb5chb4509267ecdliia68 3d0530fDa8 
huthor: Wil1l 《xxxegmail.-com> 
Tue Oct 22 14:22:33 2913 +9889 
Upqate: c-txt is changed to 333 
195 De 97ellif74ecfg9dc9ec6e4 
WUil1l 《xxxegmail.-com> 
Tue Oct 22 14:22:33 20913 +9809 
hdqd hb-txt 
ommit ac5gfae4hbh311894d6 
ill 《xxxegmail.com> 
Tue 0ct 22 14:22:33 2013 +9809 
hddq c -txt 


Oommit 5 ( 
uthor: Wil1 《xxxegmail.-com> 
Tue Oct 22 14:22:32 2913 +9889 
EL 


DOmmit 


MUil1l 《xxxe@gmail.com> 
Tue Oct 22 14:22:31 2913 +09809 


Initial commit 〈《a-txt cheated) 


:Ngit-Fehbase-demo >。 


1. 插入 一 个 commit 


接著 我 们 再 执行 一 
次 9it rebase 92f937a1l90elfca839eedq4f51dq7f7199b617 
虽 令 ， 目 前 的 Rebase 指令 如 下 : 


Dekes6s54a50Adqd EX 


EeeKREOE4056EAOGED 有 文臣 
节 有 CRao9eca79 Update eeEXLESECnandSd EGR 3 
onEel< 7 和 记 罗 GegAoieleIESIERE 


如 果 我 们 想 在 a9eca79 版 本 之 后 上 插入 一 个 新 版 
本 ， 只 要 在 a9eca79 这 行 前 面 的 pick 改 

成 eait 即 可 让 Rebase 在 重新 套用 的 过 程 中 上“ 暂 
停 , 在 这 个 版 本 ， 然 后 让 你 可 以 对 这 个 版 本 进行 
编辑 ,动作 : 


TIGKEE654ao0NaadcxE 
意 二 OS4OS6ENadE 全 攻 文 攻 
eatao9eecaAoUBadate et Senangeai ec 3Bb3 
De 和 人 [Goneiee 区 IE 


然后 存档 退出 ， 接 著 Git 会 开始 执行 套用 ， 等 执行 

到 a9eca79 这 个 版 本 时 ， 套 用 的 动作 会 被 中 断 ， 下 
提示 你 可 以 执行 9it _ commit -一 amena 重新 执行 一 
次 commit 动作 : 


:Ngit-Febase-demo>git kehbase 92f937al9g9elfca839eed4f5ld?f?199hb6ly7e3d4 一 
topped at a9ecay79 . -- Updqdate: c-txt is changed to 333 
ou can amend the commit now。 with 


9it commit 一 -amend 


DOnce you ake satisfied with youk changes。Fun 


git Fehbase --continue 


:Ngit-PFehbase-demoy> 


因为 我 们 的 目的 是 希望 在 a9eca79 这 仙 版 本 之 后 
插入 4 一 个 新 版 本 ， 所 以 我 们 可 以 直接 在 这 个 陷 
段 " 建立 新 版 本 4， ! 


例如 我 想 新 增 一 个 版 本 是 新 增 一 个 z.txt 档 
案 , ， 我 可 以 这 诬 做 : 


:Ngit-Fkebase-demo>git kehbase 92f937al9g9elfca839eed4f5ld?f ?199hb6ly7e3d4 一 
topped at a9ecay79.-- Update: c-txt is changed to 333 
ou can amend the commit now。with 


git commit -amend 
DOnce you ake Satisfied with youk changes。hFun 


9it kehbase 


:Ngit-Fehbase-demo >echo test > 2z-txt 
:Ngit-Febase-demo>git add  - 


Ngit-kehbase-demo >git Status 

HEhRD detached from 69341856 

ou ake curently editing a commit while rehbasing branch ”branchlt” on 
《use "qit commit 一 -amend'" to amend the cukrent commit》> 
《use "git Fehbase --continue'"' once you aFre Satisfied with your changes 


Changes to be committed: 
《use "qit keset HEhD 《file>.--" to unstage7) 


:Ngit-Fehbhase-demo>gqit commit "had 二 -txt 
[detached HEhRD 8?5hbzf1] hadqdq z -txt 

1 file changed。 1 insertionC+》 

chFeate mode 109644 z -txt 


:Ngit-Febase-Qdqemoy> 


我 们 执行 9it rebase --cContinue 训 Rebase 指 
令 继 续 完 成 。 最 终 完 成 的 忌 面 如 下 图 示 : 


:Ngit-Febase-dqemo>git kehbase 92f937al9g9elfca839eed4f5ldq?f?199hb6ly?7e3d4 一 
topped at a9ecay79 .- -- Update: c-txt is changed to 333 
ou can amend the commit now。 with 


gdit commit 一 -amend 


Once you ake satisfied with youk changes 。Fun 


git Fehbhase --continue 


:Ngit-Fehbase-qemo >echo test > 2z-txt 


:Ngit-Fkehbase-demo>git add - 


Ngit-Pehbase-dqemo >git Status 
HERD detached from 9B341B56 
ou ake cukkently editing a commit while kehbasing branch ”branchl”′ on 


了 


《use "qit commit -amend'" to amend the cukFent commit7》> 
《use "qit kehbase 一 -continue'"" once you ake Satisfied with your changes 


Changes to be committed: 
《use "git keset HEhRD 《file>.--" to unstage)> 


:Ngit-Febase-demo>git commit -m "hdd zz -Ext 
[detached HEhD 8?5bz?zf1] hadqdq z-txt 

1 file changed-。 1 insertionC+? 

cFeate mode 1099644 > -txt 


:Ngit-Fehbase-demo>git Fehbase --continue 
Successfu1lly zehbased and updated efs-heads-branchl . 


:Ngit-Fehbase-demo> 


最 后 我 们 用 sit 1log 查看 一 下 ， 矶 实 我 们 邮 | 风 建立 
的 Adaa z.txt 这 个 版 本 已 经 成 功 被 建立 ! 


:Nq9it-hkehase-demo>gqit 1og 
Commit 6lliioacebcgof5ly?7da4cchey7a28f5e7hbhlcb6hbhdhbhca5c7 
huthor: Wil1 《xxxegmail-com> 
Date : Tue Oct 22 14:22:33 2013 +0800 


hdq Qtxt 


ommit 875b?f19f6fa97fa279d99ad1g936a2397: 
huthor: Wil1l1 《xxxegmail-com> 
Date : Wed Oct 23 09:096:509 2013 +0800 


hdq >z -txt 


9eca793h hb45D00267e 
huthor: Wil1 《xxxegmail-com> 


Date : Tue Oct 22 14:22:33 2013 +0800 


Updqate: c-txt is changed to 333 


Commit 9034105683f6ef62f730097e11f74e 
huthor: Vi1lL1 《xxxegmail.-com> 
Date : Tue Oct 22 14:22:33 2013 +0800 


hdq hb .txt 
J)mmit 3654a5cgfae4h3118094du6a5255hbhaed907d0d199at 

huthor: Vi1lL1 《xxxegmail.com7> 

Date : Tue Oct 22 14:22:33 2013 +0800 
hadq c -txt 

Commit 32f937al9g9elfca839eedd4f51d: 

huthor: Vi1L1 《xxxegmail.com> 

Date : Tue Oct 22 14:22:32 2013 +0800 
Updqate a-txt to 2 

Commit ebpb3e52c6ab6d47ff5phbhf391Q9: 

huthor: WUil1 《xxxegmail.com> 


Date : Tue Oct 22 14:22:31 2013 +0800 


Initial commit 《a-txt cheated> 


: Ngqit-Fehbhase-Qdqemo> 


1. 编辑 一 个 commit 


编辑 一 个 commit 的 动作 ， 就 如 【插入 一 个 
commit】 的 示范 一 样 ， 你 只 要 先 把 该 版 本 修正 

为 sdit 命令 ， 就 可 以 利用 ait commit --amendq 
重新 执行 一 次 commit 动作 ， 就 等 同 於 编辑 了 某 伯 
版 本 的 纪 色 。 


1. 拆 解 一 个 commit 


拆 解 一 个 commit 纪 公 ， 代 表 的 是 你 想 要 把 肝 一 
个 commit 纪 公 ,， 继 成 两 笔 纪 从 ， 其 实 这 个 动作 跟 
【插入 一 个 commit】 绑 乎 是 完全 一 样 的 。 差别 仅 在 
於 你 只 要 把 编辑 中 的 那个 版 本 ， 将 某 些 档案 从 “ 索 
引 4 状态 中 移 除 ， 然 后 执行 sit commit --amena 
融 可 以 建立 一 个 新 版 。 然 后 再 执行 sit adq . 重新 
把 这 些 档案 加 入 ， 然 后 再 执行 sit commnit， 即 可 
将 原本 一 个 版 本 的 释 更 ， 继 成 两 个 版 本 。 


1. 压缩 一 个 commit, 且 合 供 讯息 纪 销 


所 谓 的 “压缩 一 个 commit 版 本 ， ， 代 表 你 这 炎 个 
版 本 中 ， 有 个 版 本 讯息 有 点 多 余 ， 而 且 几 得 可 以 把 
这 个 版 本 的 释 更 合 偿 到 “上 一 个 版 本 ,， (parent 
commib 中 ， 那 床 你 可 以 修改 Rebase 指令 ， 


把 pick 修改 为 sauash 即 可 。 


透 过 感 缩 的 方式 ， 被 套用 squash 命令 的 版 本 ， 其 
版 本 纪 和 俏 讯息, 会 被 自动 加 入 到 " 上 一 个 版 本 ， 
的 讯息 中 。 


1. 压缩 一 个 commit， 但 丢 素 版 本 纪 销 


如 果 你 只 想 合 儒 两 个 版 本 的 变更 ， 但 不 需要 合 儒 纪 
色 讯 息 的 话 ， 那 和 你 可 以 修改 Rebase 指令 ， 
把 pick 修改 为 fixup 即 可 。 


1. 删除 一 个 commit 


删除 一 个 commit 版 本 是 最 简单 的 ， 只 要 直接 把 要 
删除 的 这 几 行 pickx 命令 给 移 除 即 可 。 


今日 小 短 


看 到 这 壬 ， 你 应 该 能 感受 到 Rebase 的 强大 威力 。 

透 过 sit rebase 可 以 有 效 帮 你 " 重 整 版 本 ，， 不 
但 让 你 的 Git 版 本 记 色 更 加 易 懂 ， 也 更 有 跑 辑 。 这 
生 做 的 好 处 ， 在 多 人 开发 的 Git 专案 中 尤其 明显 ， 

为 了 你 的 转 队 成 员 著 想 ， 各 位 不 得 不 学 啊 ! 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git rebase -1 [commit_ id] 
。git commit --amend 


。 HOME 
。 回 目 销 
。 前 一 天 : 修正 commit 过 的 版 本 历史 纪 杀 Part 


4 (rebase) 


。 下 一 天 : 使 用 GitHub 踪 端 储存 库 - 入 门 篇 


第 24 天 : 使 用 GitHub 过 问 
储存 库 - 入 门 扁 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/24.md 


GitHub 是 目前 全 世界 最 多 人 探 用 的 Git 线 上 管理 平 
台 ， 他 包含 了 完整 的 Git 让 端 储存 库 实 作 ， 还 有 完 
整 的 议题 追 跳 机 制 与 报表 ， 更 有 成 二 上 和 万 的 开源 码 
专案 都 在 GitHub 进行 Git 版 本 控 管 。 即 便 在 我 们 公 
司 ， 也 有 许多 专案 探 用 GitHub 当成 我 们 主要 的 Git 
平台 。 本 扁 文 章 主要 帝 大 家 上 手 GitHub 最 基本 的 
使 用 方 陈 。 


我 们 先 来 说明 在 GitHub 建立 专案 的 两 种 不 同 的 方 
趟 。 

在 GitHub 建立 一 个 上 “没有 版 本 , 的 空 
白 Git 储存 库 


先 登 入 GitHub， 再 进入 GitHub 首页 : https:/ 


github.com 


盟 选 右 上 角 你 的 使 用 者 名 称 进 入 个 人 首页 : 


Blog Help 辕 doggysosg | 熙 光 办 
S 


)ositories ” 愉 Public Activity EditYour Profile 


Repositories contributed to 


10 食 略 0 食 
118 食 和 0 食 
89 食 加 一 682 食 


() 量 名 Explore Gist Blog Help 
加 contributions | 目 Et 有 NPublic ， 
Search 


再 点 选 右 稳 缚 色 的 New 按钮 ， 以 建立 一 个 你 自己 
的 GitHub 专案 (包含 Git 踪 端 储存 库 ) : 


Blog Help 置 doggy8088g 上 浆 邓 


positories ”从 Public Activity 必 EditYour Profile 


Search All Public Privaie Sources Forks “| 匡 呈 | 


9 仿 0 8?0 


如 果 你 要 建立 一 个 "没有 版 本 , 的 空白 Git 储存 
库 ， 好 重要 的 就 是 最 下 方 的 Initialize this 
repository with a README 不 要 勾 愤 ， 还 有 Add 
.gitignore 与 Add alicenes 都 保留 预 设 的 None 


遗 项 : 
Owner Repository name 
置 doggy8088 - /| sandbox-empty| wW 


Great repository names are short and memorable. Need inspiration? How about mas 


Description (optional) 


二 .Public 
Anyone can See ihis repository. You cho0se who can commiit 


口 Private 


You choose who can See and committo this repository 


口 Initialize this repository with a README 
This will allow youto git clcne 如 erepository immediately 


&dd gitignore- None ~ Add alicense- None ~ 


Create repository 昌 


最 后 按 下 Create repository 即 可 建立 完成 ， 当 你 
建立 起 一 个 "没有 版 本 , 的 空白 Git 储存 库 之 后 ， 
划 面 下方 也 提 到 队 信 作 上 人 本 地 Git 储存 库 
的 指令 教学 ， 照 著 打 就 可 以 把 本 地 储存 库 的 释 更 上 
传 到 GitHub 的 踪 端 储存 库 中 。 


doggy8088 / sandbox-empty 


和 setup 一 iyouve done this kind ofthing before 


| 工 


2 We recommend every repository include a README. LICENSE. al 


Create a new repository on the comr 


touch README .md 
git init 
git add READNME .md 


Eit commit -mm "first Commit" 


git _ remote add origin https://Eithub.com/dogEgy8688/sandbox-empty ,.Eit 
git push -U origin master 


Push an existing repository from the co 


Egit remote add origin https:/V/egithub.com/doggy8888/sandbox-empty.Eit 


git push -U origin master 


在 GitHub 建立 一 个 有 初始 化 版 本 ， 
的 Git 储存 库 


建立 一 个 " 有 初始 化 版 本 + 的 空白 Git 储存 库 ， 其 
实 就 是 在 GitHub 建立 专案 时 ， 勾 选 了 一 些 初始 化 
的 档案 ， 在 建立 的 过 程 GitHub 会 依据 你 所 挑 玩 的 
选项 ， 先 草 你 建立 好 一 个 初始 化 的 Git 版 本 : 


Owner Repository name 


置 doggy8088 ~ /| sandbox-initialized 


Great repository names are short and memorable_ Need inspiration? How about beal 


Description foptional) 


全 :Public 
Anyone can See this repository. You choose who can commit 


〇 -Private 
You choose who can see and committo this repository 


Initialize this repository with a README 
This will allow youto git clonethe repository immediately 


Add .gitignore- CSharp Add alicense- GPL v2 ~ 


Create aa 


建立 完成 后 ， 在 GitHub 上 显示 的 内 容 会 不 太一 
样 ， 因 为 你 已 经 有 一 个 commit 版 本 在 上 面 了 : 


doggy8088 / sandbox-initialized 


Description Website 


1commit 1 branch 0 reieases 


P pranch: master ~ sandbox-initialized / 卓 


Initial commit 


吕 doggy8088 suihored jusino 


gftignore Inital commit 


LICENSE initial commit 


夯 砚 | 


README.md Initial commnit 


README.md 


sandbox-initialized 


将 本 地 储存 库 的 释 更 上 传 到 过 问 储 存 认 
的 方法 

我 有 在 【第 03 天 : 建立 储存 库 】 这 篇 文章 中 提 到 
如 何 取得 从 GitHub 建立 的 下 端 储存 库 (remote 
repository)， 不 过 若 要 将 本 地 释 更 送 上 GitHub 则 有 
好 伙 种 不 同 的 方式 ， 其 中 包括 : 


1. 在 GitHub 建立 一 个 :没有 版 本 + 的 空 日 Git 
储存 库 ， 然 后 透 过 sit clone 取得 还 端 储存 


库 ， 再 建立 版 本 和 后 上 传 

2. 在 GitHub 建立 一 个 ' 洛 有 版 本 4 的 空白 Git 
储存 库 ， 然 后 直接 将 现 有 的 本 地 Git 储存 库 上 
传 到 指定 的 GitHub 专案 

3. 在 GitHub 建立 一 个 " 有 初始 化 版 本 :4 的 Git 
储存 库 ， 然 后 透 过 sit clone 取得 让 端 储存 
库 ， 再 建立 版 本 后 上 传 

4. 在 GitHub 建立 一 个 " 有 初始 化 版 本 :4 的 Git 
储存 库 ， 然 后 直接 将 现 有 的 本 地 Git 储存 库 上 
传 到 指定 的 GitHub 专案 


以 上 就 是 我 们 首次 使 用 GitHub 时 ， 最 常见 的 四 种 
上 传 方式 。 厄 格 说 起 来 ， 上 述 四 种 上 传 方式 ， 应 该 
只 有 两 种 而 已 ， 也 就 是 : 


1. 透 过 sit clone 取得 这 端 储存 库 ， 再 建立 版 本 
后 上 传 

2. 直接 将 现 有 的 本 地 Git 储存 库 上 传 到 指定 的 
GitHub 专案 


义 什 么 我 想 拆 成 四 个 来 讲 呢 ? 主要 有 两 个 原因 : 


1.【 租 过 sit clone 取得 这 端 储存 库 ， 再 建立 版 
本 后 上 传 】 的 这 种 方式 ， 因 为 "没有 版 本 4 的 
空 日 Git 储存 库 ， 束 预 设 的 master 分 广 都 疫 


有 ， 所 以 用 预 设 的 指令 无 法 上 传 到 未 端 储存 
库 。 所 以 在 指令 操作 上 会 有 两 种 用 法 。 

2. 【直接 将 现 有 的 本 地 Git 储存 库 上 传 到 指定 的 
GitHub 专案 】 的 这 种 方式 ， 因 为 通常 一 个 Git 
储存 库 只 会 有 一 个 "初始 commit 物件 ， ， 如 
果 你 在 本 地 储存 库 已 经 建立 了 绑 个 版 本 ， 代 表 
在 你 的 本 地 储存 库 中 已 经 有 了 上 自己 的 :初始 
commit 物件 ， ， 这 将 会 且 GitHub 建立 的 有 
初始 化 版 本 :4 的 Git 储存 亩 相互 征 突 ， 所 以 上 
传 的 指令 也 会 有 些 不 同 。 


以 下 我 们 先 来 说 明 【 透 过 gsit clone 取得 踪 端 储存 
库 ， 再 建立 版 本 和 后 上 传 】 这 个 方法 。 


透 过 gGit ClLone 取得 和 这 端 储 存 库 7 再 建立 
版 本 和 后 上 传 


这 个 方法 最 简单 ， 因 为 你 迁 没有 本 地 储存 库 的 存 

在 ， 甚 至 巡 工 作 目 杀 都 还 没 有 ， 所 以 我 们 直接 利 

用 sit clone 即 可 把 专案 下 载 。 然 而 ， 在 使 用 
GitHub 的 时 候 ， 最 简单 的 方法 就 是 利用 GitHub for 
Windows 工具 。 你 只 要 点 机 Clone in Desktop 按 
钮 ， 即 可 自动 衣 动 GitHub for Windows 工具 才 你 下 
载 Git 专案 


。 “没有 版 本 + 的 空白 Git 储存 库 


doggy8088 / sandbox-empty 


Quick setup 一 上 youve done this kind of thing before 


便 Setup in Desktop or 
局 


-4 ps://github.com/doggy8088/sandbox-emPpty. 


SR 


。 “有 初始 化 版 本 + 的 Git 储存 库 


0UC 4 
SSH, or Su Sion 
较 clone in Desktop 
晤 


宁 Download ZIP 


你 也 可 以 直接 复 揭 GitHub 提供 的 URL 网 址 ， 然 后 
利用 9it clLone 指令 下 载 ， 例 如 : 


:N?g9it clone https:--githuhb com/doggyv8988/sandbox-empty-git 
loning into :Sandbox-empty' --- 
waFPning: You appear to havue cloned an empty Fepositorvy- 


:N?>g9it clone httpbs:--githuhb .comdoggyv80988-sandbox-initialized.git 
loning into "Sandhbox-initialized' . - - 
emote: Counting objects: 5。done - 
vemote: Compressing ohbjects: 109 上 《44>。 done - 
remote: Total 5 〈delta 0>。hFeused 9 《delta > 
npacking ohbjects: 199x 〈5-5>。done - 


:N>dir Sandjbox 一 关 
太 避 芒 全 从 是 TEMPORRRY 


世 
83D7-4999 


《DIR> Sandhbox-empty 

《DIR> sandhbox-initialized 
5 

4-954-642-688 


用 ait clone https://dithub .com/dqoggy8088/sandbox- 
复 提 一 个 “没有 版 本 4 的 空白 Git 储存 库 ， 将 会 得 
到 一 个 warning: You appear to have cloned an 
empty repository. 警告 讯息 ， 不 过 这 不 影响 你 上 


传 本 地 的 继 更 。 


如 果 你 

用 ait clone https://dithub .com/dqoggy8088/sandbox- 
复 由 一 个 “有 初始 化 版 本 , 的 Git 储存 库 ， 将 会 直 

接 从 GitHub 下 载 所有 完整 释 更 历史 的 【和 束 端 储存 

所 以 你 会 看 到 有 下 载 物件 数量 、 压 缩 、 解 压 


我 们 以 Sanaqbox-empty 这 个 专案 为 例 7 由 於 这 是 一 


个 上 没有 版 本 , 的 空白 Git 储存 库 ， 在 GitHub 上 
的 束 端 储存 库 是 完全 空 的 ， 囊 预 设 的 master 分 文 
都 没有 ， 所 以 在 下 过 sit push 指令 时 必须 加 上 -ua 
参数 ， 才 能 成 功 地 把 本 地 储存 库 上 传 到 GitHub 上 
的 束 端 储存 订 ， 其 指令 

是 git push -u origin master 


:N\>cd sandbox-empty 


:\sandbox-empty>git 1og 
atal1: bad qdqefault euision “HEhD 


:N\sandbox-empty>git Status 
On branch master 


Initial commit 


othing to commit 《ckFeate/copy files and use "9git aqdd" to tkFack)> 


dhbox-empty>echo aa > -txt 直 


:sandbox-empty>git add - 


:sandbox-empty>git commit -~m “Initial commit” 
[master 《koot-commit》 897e378] Initial commit 

1 file changed。 1 insertionC+》> 

create mode 1699644 a-txt 


:sandbox-empty>git push -u okFigin master 
name for :https:-Agithuhb-com': doggyv8D88 

Password for "https:- doggyv8988egithupb .com' : 

ounting ohbjects: 3。done - 

S: 199x 〈3/3>。212 byvtes } 昌 byvtes/S。done- 

otal 3〈delta 89。PFeused 89 《delta 8)》 

0 https:-Agithuhb .comvdoggy86888/sandbox-empty-git 

关 [new hbranch] mastekrkr 一 >》 mastekr 

Fanch mastekr Set up to tkhack Femote branch mastekr fkrom okFigin . 


:\sandhbox-empty>e 


P branch: master ~ | sandbox-empty / 掉 


目 atxt Initial commit 34 minutes ag0 


我 们 再 以 sandqbox-initialized 这 个 专案 为 例 , 由 


於 这 是 一 个 “有 初始 化 版 本 : 的 Git 储存 库 ， 在 
GitHub ub 上 的 遗 端 储存 已 经 有 一 个 版 本 ， 同 时 也 建 
立 好 预 设 的 master 分 广 ， 所 以 在 下 巡 sit push 
指令 时 可 以 不 用 加 上 -ua 参数 ， 就 成 功 地 把 本 地 储 
存 库 上 传 到 GitHub 上 的 这 端 储存 库 ， 其 指令 


是 9it Push oridin masteL 


:Nsandbox-emptyz>cd -- 
:N\>cd sandhbox-initialized 


:N\sandhbox 一 人 1o9 
ji 9697hbhbh53f698d9ea6f9d31hb6?792f24f2747: 
: Will 保 哥 《 
Thu Oct 24 686:27:54 2013 -0700 


Initial commit 


:N\sandhbox-initialized>gqit branch 


:\sandhbox-initialized>echo aa > aa-txt 
:N\sandhbox-initialized>git add - 


:N\sandhbox-initialized>git commit -m "hddqd atxt” 
[mastekr d4hbcle5] hadqdq a-txt 

1 file changed。 1 insertionC+7》> 

ckeate mode 1099644 a-txt 


:N\sandhbox-initialized>git push origin mastekr 

Sekname foFr "https:-A9githuhb com : dogqguv8088 

Password for "https:-doggyv8988egithupb com: : 

ounting ohbjects: 4。done - 

IDpelta compFession using up to 8 threads - 

ompkessing ohjects: 1009x 《2-2>。done - 

Jriting ohbjects: 1009 上 《3-3>。265 bytes 上 1 0 bytes/S。done - 

otal 3 《delta 1>。hFPeused 9 《delta D) 

0 httpbs:~-githuhb .comdoggyv8988/-sandhbox-initialized-git 
39697bhb. .qd4bcle5 mastekr -> mastekr 


:\sandhbox-initialized>。 


当 你 第 二 次 建立 版 本 时 ， 直 接 执 行 sit push 就 会 
目 


:\sandhbox-initialized>git 1og --oneline 
4hc hdqd a-txt 
JD6D7pbhbh Initial commit 


:\sandbox-initialized>echo hb > hb-txt 
:vsandhbox-initializeq>gqit add  - 


:\sandhbox-initialized>git commit -m "hdd hb-txt” 
[master 5788hb9c] haqq hb .txt 

1 file changed-。 1 insekrtionC+7> 

chFeate mode 199644 b-txt 


:\sandhbox-initialized>git push 

aning: push.-dqefault is unsetji its implicit ualue is changing in 
it 2.9 from matching” to "simple'*。 To squelch this message 

nd maintain the cukkent behauiokr after the default changes。 


git config --glohbal push.default matching 


Do Sduelch this message and adopt the new hbehauior now。use: 


git config --glohbhal push.dqefault simple 


”9git help config” and seakch for "push.default”′ for further information - 
Simple” mode was intkroduced in Git 1.7.11. Use the similar mode 
curFent” instead of "Simple” if you sometimes use 0lduer uvuekrsions of Git》 


Sekname for 'https:/ /Agithuhb .com doggqy8988 

assword for :https:-[doggy8988egithuhb com' : 

ounting ohbjects: 4。done - 
Delta compkession using up to 8 threads - 

omphessing ohbjects: 109X 上 《2-2>。done - 

Writing ohbjects: 199x 《3-3>。266 bytes 1 日 bytes/S。done- 
otal 3《〈delta 1>。Feused 9 〈delta 昌 )> 

0 https:/ /Agithuhb -com/doggy8988/sandhbox-initialized-git 

d4hbcle5 . .5788hb9c ”master -> master 


:\sandhbox-initialized>。 


P master ~ 1 


不 过 ， 当 你 执行 简单 版 本 的 sit push 会 出 现 一 段 


国 
提示 告诉 你 要 设 定 Push.aefault 这 个 遗 项 7 


为 这 种 简 元 的 sit push Git 的 预 设 行为 将 会 
在 Git 2.0 之 后 发 生 改 释 ， 建 议 你 透 过 设 

定 push.default push 的 方 
法 。 详 细 说 明 请 参见 sit help config 的 说 明文 
件 ， 搜 时 push.daefault 即 可 找到 相关 说明 。 我 建 
议 各 位 设 定 成 simple， 以 利 跟 日 后 的 Git 指令 列 工 
具 的 预 设 值 相 同 ， 指 令 如 下 : 


GE 三 全 所 亲 有 证 9 是 二 gbaalilausheaeamieESsmiee 


设 定 好 之 人 后， 下 次 执行 sit push 就 不 会 再 出 现 提 
示 讯 息 了 : 


:N\sandhbox-initialized>gqit config --9lohbal push.-default simple 


:N\sandhbox-initialized>echo c > c-txt 
:N\sandhbox-initialized>git aqdd - 


:N\sandhbox-initialized>gqit commit -m "hdQqd c .txt 
[mastekr 8598135] hdqqd c -txt 

1 file changed。 1 insekhtioncK+?> 

chFeate mode 199644 c -txt 


:N\sandhbox-initialized>gqit push 

Sekname foFr https:-A9ithupb.-conm' : doggyv80688 

Password for https:-ndoggy80988Bgithupb com” : 

ounting ohbjects: 4。done - 

IDpelta compFhession using up to 8 threads - 

omphkessing ohbjects: 100x 〈2-27>。done - 

Jriting ohbjects: 109x 《3/-3>。266 bytes 1 0 byvtes/S。done- 

otal 3 《delta 1>。hFeused 9 《delta 昌 > 

0 httpbs:-“Agithuhb .comdoggyv8988-sandhbox-initialized-git 
5788hb9c - -8598135 mastekh 一 > mastek 


之 后 的 操作 ， 在 我 们 这 两 个 练习 用 的 工作 目 销 都 完 
全 一 样 。 


:N\sandhbox-initialized>cd .--Nsandbox-empty 
:Nsandhbox-empty>echo hb > hb-txt 
:N\sandhbox-empty>gqit add - 


:N\sandhbox-empty>git commit -mn “had hb.-txt” 
[mastekr 4chb5f45] hadqq hb-txt 

1 file changed。 1 inseFrtionC+7> 

chkeate mode 1968644 b.txt 


:N\sandhbox-empty>gqit push 

Sekhname foFr "https:--9qithuhb com : dogqguv8088 
PasswoFrd for :https:-ndoggy8988egithupb com: : 
ounting ohbjects: 4。done - 


IDpelta compFession using up to 8 threads - 

ompkessing ohbjects: 1009x 《2-22>。done - 

Jriting ohbjects: 109x 《3A-3>。266 buvtes 上 1 0 hvtesS。done - 

otal 3 《delta B8>。hFeused 9 《delta 昌 ) 

0 https:~“-githuhb .com/doggyv8988/sandhbox-emptvy-git 
897e378 . .4chb5f45 mastekr -> mastekr 


直接 将 现 有 的 本 地 Git 储存 库 上 传 到 指 
定 的 GitHub 专案 


接 下 来 我 们 再 来 说 明 【 直 接 将 现 有 的 本 地 Git 储存 
库 上 传 到 指定 的 GitHub 专案 】 过 个 方法 。 但 由 於 
练 避 用 的 GitHub 专案 已 经 被 上 传 一 些 物件 ， 所 以 
请 各 位 重新 再 建立 两 个 新 专案 ， 分 别 是 一 个 “ 冯 
版 本 4 的 空 日 Git 储存 库 ， 与 另 一 个 "有 初始 化 版 
本 , 的 Git 储存 库 。 


一 个 "没有 版 本 : 的 Git 储存 库 ， 专 案 名 


称 : sandbox-empty2 一 个 上 有 初始 化 版 本 的 空 
Git 储存 库 ， 专 案 名 称 : sandqbox-initializeqd2 


接著 我 们 建立 两 个 本 地 储存 亩 与 工作 目录 ， 指 令 如 
下 : 


mkdqir Sandqbox-empty2 
cd _ sandqbox-empty2 


GRASS 


SITE EECOE 
血本 司 人 olis 和 


gasecOmmaxe mnansca eicemmaaea 


[SEE 
mkKkdir sanaobox=-1nltliallizeaQ2 


cq _ sandqbox-initial1ized2 
GREENte 
SENOEE ECOE 


人 


Geecune EECIEIOGCinaDe 


我 们 先 以 sandqbox-empty2 专案 为 例 ， 由於 我 们 本 

地 储存 库 跟 GitHub 上 的 过 端 储存 库 完 全 没有 关 

和 ， 所 以 必须 告诉 Git 下端 储存 亩 在 哪 。 这 时 我 们 

可 以 输 

入 9it remote adq origin https://gqithub .com/doddqy8 
建立 一 个 名 为 origin 的 参照 名 称 ， 站 指 

加 https://github .com/doggy8088/sandbox-empty2.git 
位 址 ， 也 就 是 我 们 在 GitHub 上 的 和 趟 端 储 存 库 位 

址 。 接 著 就 跟 我 们 先前 讲解 的 步 桑 一模一样， 如 下 

图 示 : 


:Nsandbox-empty2>git Femote 忆 origin ht 


:vsandbox-empty2>git branch 


接著 我 们 再 以 sandbox-initializeqd2 专案 为 例 ， 
请 记得 复 抽 到 正确 的 URL 位 址 : 


Settings 


HTTPS 


Etps:7 /GEithub .cor hh 


加 Clone in Desktop 


cp Download ZIP 


然后 输入 跟 以 上 相同 的 指令 (记得 改 URL 
喔 ) : 9it remote aqq origin https://dgithub .com/dqodd 


https :AL]githuhb-comvdoggy8B88/sandhbox-initialized2.git 


你 可 以 发 现 ， 这 次 的 sit push 动作 被 GitHub 拒 
纪 了 ! 因为 你 不 能 把 两 个 完全 无 关 的 Git 版 本 直接 
上 传 到 GitHub 上 的 踪 端 储存 库 。 


解决 的 方法 很 简单 ， 只 要 把 这 端 储存 库 的 master 
分 支 ， 成 功 合 供 回 我 本 地 的 分 支 ， 即 可 建立 两 个 不 
同 版 本 库 之 间 的 关联 ， 过 样 你 就 可 以 把 本 地 


的 mastez 分 支 推送 到 GitHub 上 下端 储存 库 
的 masteL 分 支 了 。 


将 还 端 储存 库 的 master 分 支取 回 ， 站 合 伴 到 本 地 
储存 库 的 master 分 支 ， 有 两 种 方法 : 


1 . 使 用 9it Pull oridgin masteL 指令 
2. 使 用 9jt fetch 指令 和 后 再 执 
行 9jit merde origin/masteL 合 儒 动 作 (这 个 


方法 会 在 和 后续 的 文章 详 述 ) 


先 用 sit --version 查看 自己 的 版 本 ， 和 若 你 的 Git 
版 本 是 2.8.4 (包含 ) 以 前 ， 你 可 以 成 功 合 代 ， 


成 功 执 行 的 过 程 如 下 图 示 : 


:sandhbox-initialized2>g9it pull origin master 


wakning: no common commits 
Counting objects done - 
Compressing ohbjects: 1D9 上 《4-4>。 done - 
Total 5 〈delta 89。hFeused 9 〈delta 98) 
npacking ohbjects: 109x 《5-5>。done - 
kom https:--githuhb .com/doggy86988/sandhbox-initialized2 
闪 branch master -> PETCH_HEhD 
eFge made by the "Fecursiue”′ stFategvy- 
-9itignore 上 198 
LICENSE 339 
RERDME .md 2 
3 files changed。449 insertionsK+) 
chkeate mode 1099644 .9gitignoFe 
cheate mode 199644 LICENSE 
ckeate mode 199644 RENDME.md 


xsandhbox-initialized2>9git push origin master 
kname forkr ”httpb: Agithuhb .com” : doggyv8088 
Password for "https:-doggy80988egithub com”: 
ounting ohbjects: 6。done- 
iDpelta _ compression using up to 8 threads - 
ompkessing ohbjects: 109x 《3/3>。done - 
Jriting ohbjects: 199Xx 《5-5>。596 byvtes 上 1 日 byvtes/S。done - 
otal 5〈delta 1>。hFeused 9 《delta 90) 
0 https:/-githuhb .com/doggyv8888/sandhbox-initialized2 .git 
d3al3?9. -1caf362 masteFr -> master 


:\sandhbox-initialized2> 


但 是 从 cit 2.9.0 开始 ， 预 设 行为 不 允许 合 代 没 
共同 但 先 的 分 支 : 


git remote add origin https Ht dbox-initialized2.git 


t pull orlgin maste 


andbox-in tia 
FETCH_HEAD 
or 


related h 


需要 加 上 --allow-unrelatedq-histories 人 允许 Git 


合 供 没 有 共同 祖先 的 分 支 。 


因此 完整 指令 


二 9it Pull oridgdin master --alLlLow-unrelated-histor 


ow-unrelated-histories 


0 (delta 
100% (1Z1)， 


6G:Asandbox-initialized2 


今日 小 结 


本 篇 文章 完整 的 介绍 如 何 将 本 地 储存 康 上 传 到 

GitHub 上 的 下 端 储存 库 ， 内 然 过 程 有 点 麻烦 ， 但 如 
果 你 透 过 GitHub for Windows 操作 的 话 ， 要 上 传 到 
GitHub 只 要 简单 的 按 下 sync 按钮 ， 就 可 以 自动 上 
传 了 ， 填 帐号 密码 都 不 用 输入 ， 这 样 是 不 是 简单 很 


多 。 (^ 人 和 ^) 


sandbox-initialized 


s 


no local changes 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


git push origin master 

git push -u origin master 

git pull origin master 

git config --global push.default simple 
git push 

git fetch 

git merge origin/master 

git --Vversion 

git pull origin master --allow-unrelated- 
histories 


HOME 

回 目 凶 

前 一 天 : 修正 commit 过 的 版 本 历史 纪 杀 Part 
5 (rebase 2) 

下 一 天 : 使 用 GitHub 带 端 储存 库 - 秽 念 篇 


第 25 大 : 使 用 GitHub 过关 
储存 库 - 秽 念 扁 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/25.md 


上 一 篇 大 家 学 会 了 如 何 下载 踪 端 储存 库 

(it _ clone，git pul1) 与 上 传 带 端 储存 库 

(Sit push)， 本 篇 文章 来 教 大 家 认识 还 端 储存 库 的 
其 他 细节 。 


与 未 冰 储 存 库 有 关 的 指令 


。 dg9it clLone 


将 这 端 储存 库 复 揭 到 本 地 ， 冰 建 立 工 作 目 杀 和 与 
本 地 储存 库 (就 是 .sit 资料 来 ) 


2 何 开 七: 瑟 右 二 寺 


将 带 端 储存 库 的 最 新 版 下 载 回 来 ， 下 载 的 内 容 
包含 完整 的 物件 储存 库 (object storage)。 芷 且 


将 带 端 分 支 合 供 到 本 地 分 支 。 


(将 origin/master 带 端 分 支 合 儒 到 SSEe 


本 地 分 支 ) 
所 以 一 个 sit pull 动作 ， 完 全 相等 於 以 下 两 
段 指 令 : 


9it fetch 


9it merge origdin/masteL 


二 Sn 


将 本 地 储存 库 中 目前 分 支 的 所 有 相关 物件 推送 
到 运 端 储存 库 中 。 


。 dit fetch 


将 下端 储存 库 的 最 新 版 下 载 回来 ， 下 载 的 内 容 
包含 完整 的 物件 储存 康 (object storage)。 这 个 
命令 不 包含 〔“ 合 任 ， 分 支 的 动作 。 


。 9ijit 1S-zemote 


人 下 古人 多 全 库 的 参照 名 称 。 包 含 带 端 分 


关於 妃 跳 分 支 的 概念 


我 们 先前 学 习 过 关於 分支: 的 概念 ， 不 过 仅 限 於 
[本 地 分 支 !， 今 天 我 们 多 出 了 个 踪 端 分 支 ! ， 事 
情 融 相对 复杂 一 些 。 


基本 上 ， 当 我 们 的 版 本 控 管 流程 加 上 了 下端 储存 库 
之 人 后， 原本 的 分 文 就 可 以 被 拆 成 四 种 不 同 的 概念 : 


目的 是 用 来 追 跳 分 支 的 变 
化 情形 。 通 常 焉 端 分 支 你 是 存 取 不 到 的 。 


当 你 执行 9it clLone 复 揭 一 个 下端 容 器 回来 之 
人 后， 所 有 迁 端 追 跳 分 支 会 被 下 载 回来 ， 普 且 相 
对 应 的 建立 起 一 个 同名 的 本 地 追 跳 分 支 。 


我 们 以 复 拒 jQuery 在 GitHub 上 的 专案 为 例 ， 


透 


过 djit clLlone https:/ /dgithub.com/Jjduery/Jjduery. 


下 载 回来 后 7 执行 glit branch 一 a 指令 颗 
示 出 所 有 本 地 分 支 生 上 本 地 追 跳 分 支 ,。 
“本 地 追 跳 分 支 , 就 是 如 下 图 红字 的 部 分 : 


29212 《de lta 2115987> 
B8 MiB ; 685 -99 KiB/s。done- 


3. 本 地 分 支 


在 透 过 5it branch 指令 执行 时 所 显示 的 分 
支 ， 就 是 所 谓 的 “本 地 分 支 ， ， 这 些 分 支 存 在 
於 本 地 端 ， 而 这 些 分 支 又 常 被 称 为 主题 分 支 
(Topic Branch) 或 开发 分 支 (Development 
Branch)， 就 是 因为 这 些 分 支 预 设 不 会 被 推送 
到 和 带 端 储存 库 ， 主 要 用 来 做 开发 用 途 。 


4. 这 端 分 云 


顾 名 思 闵 ， 踪 端 分 支 就 是 在 这 端 储存 库 中 的 分 
支 ， 如 此 而 已 。 如 果 你 用 GitHub 的 话 ， 你 是 
无 法 存 取 舟 端 分 支 的 。 


只 然 说 “概念 上 , 可 以 分 为 这 四 类 ， 但 其 实 这 
些 分 支 就 只 是 参照 名 称 而 已 ， 而 这 和 里 的 追 中 
分 支 : 主要 惑 是 用 来 跟 让 端的 分 支 做 对 应 ， 你 


不 应 该 直接 在 这 些 分 支 上 建立 版 本 (只 然 你 还 
是 可 以 这 廊 做 ， 但 强烈 不 建议 融 搞 )， 而 是 把 这 
些 "本 地 追 跳 分 文 : 视 筷 是 一 种 5 唯 读 J 的 分 
2 


计 册 过 端 储存 库 
我 们 在 上 一 篇 有 提 过 可 以 透 过 dit remote 指令 
动 加 入 一 个 逐 端 储存 康 ， ， 例 如 : 


GEEEEmos5qaOCIOTNEIEEDSsomenuoeonmabggvy80 


这 个 origin 名 称 是 在 Git 版 本 控 管 中 惯用 的 预 设 
衣 端 分 支 的 参照 名 称 ， 主 要 目的 是 用 来 代表 一 个 踪 
闫 储存 库 的 URL 位 址 。 


不 过 ， 事 实 上 你 可 以 在 你 的 工作 目录 中 ， 建 立 多 个 


踪 端 储存 库 的 参照 位 址 。 例 如 我 们 
以 sandbox-empty2 这 个 专案 为 例 ， 我 们 先 复 抱 回 
来 7 然后 透 过 9it remote 一 V 可 列 出 目前 广 册 在 工 


作 目 销 里 的 各 端 储存 库 资 讯 。 如 果 我 们 额外 将 
jQuery 的 束 端 储存 库 也 一 供 下 载 回来 ， 则 可 以 用 以 
下 指令 先行 主 册 一 个 名 称 起 来 。 


9it zemote aqddq jdquezcy https://githuab .com/ jeguery/ 


最 后 再 用 sit fetcnh 指令 把 完整 的 jQuery 这 端 储 


和 存 库 一 人 下 载 回来 ， 完 整 的 执行 过 程 如 下 图 示 : 


it clone httpbs:- Agithuhb .com/doggyv8B88/sandbox-empty2 .9git 
ji into "Sandhbox-empty2”-.-- 
Counting ohbjects: 3。done- 
Total 3 《delta @>。Feused 3《〈delta )> 
npacking ohbjects: 169x 《3/3>。done - 


:N\>cd sandbox-empty2 
:sandbox-empty27>9git Femote 一 v 


origin https:/]githup-conmzaoggy8988/sandbox-empty2.git 〈fetch) 
orkigin httpbps:-Agithuhb .comxdoggy8988/ sandhbox-empty2 .9git 《push> 


:Nsandhbox-empty2>git kemote add jque httpbs:-githupb .com/jdqueryjquery .gtit 


:sandbox-empty2>9it kemote 一 v 

jqueFry https:-Agithub .comjqueryjquery-git 《ffetch> 

jquery http Agithub .comjqueryjduery-git 《push) 
http: ~-githupb .com/doggy8688/sandhbox-empty2.git 《〈fetch》 
httpbs:-“-github .com/doggyv8688/sandhbox-empty2 .9git 《push)> 


:\sandbox-empty2>git fetch jdquery 
aning: no common commits 
emote: Counting objects: 39853。done . 
emote: Compkessing objects: 199X 《9973“-9973>。 done - 

Total 39853 《delta 22699>。heused 292109 《delta 211497) 
eceliuing objects: 1099x 〈39853/39853>。15 -98 MiB ! 166.099 KiB/s。done- 
esoluing deltas: 199x 《22699/-22689>。 done - 

From https:-Agithuhb.-comjqueryjquery 
[new branch] #13388 -> jdqueruyA#tl3388 
[new branch] 1.8-stahble -> jdqueryxL .8-stable 
[new branch] 1.9-stahble -> jqueryvL .9-stahble 
[new branch] 工 -.x-mastekr ->》 jdqueryvAI .x-master 
branch] ajax-sckipt-2.-09 -> jdqueru/ajax-sckipt-2.0 
hbranch] ajax-unit -> jdqueryajax-unit 
hbranch] master -> jdqueryAmaster 
了 . 3 谋 二 少 : 生 站 二 卫 二 


洲 玉米 凡凡 素 素 则 


你 可 以 看 到 ， 我 们 事 喜 上 可 以 在 一 个 Git 
中 ， 加 入 许多 相关 或 不 相关 的 这 端 储存 库 ， 这 些 复 
秽 回 来 的 完整 储存 库 ， 都 包含 了 这 些 储存 庆 中 的 所 
有 物件 与 继 更 历史 ， 这 些 Git 物件 随时 都 可 以 堪 ; 

运用 。 不 过 ， 通 常 我 们 广 册 多 个 踪 端 储存 库 的 机 会 


普 不 多 ， 除 非 你 想 抓 特 其 他 转 队 成 员 的 版 本 库 回 来 


这 些 主 册 进 工作 目 销 的 下端 储 存 库 设 定 资 讯 ， 都 储 
存在 .sit\config 设 定 档 中 ， 其 内 容 如 下 范例 : 


[zemote "originy"] 

Url = https://github.com/dqoggy8088/sanadqbox-empt 
fetch = +trefs/headqs/*:Trefs/remotes/oridin/r 
[zemote "Jjdquery"] 

了 本 三 本 让 世 记 SEOSSESmXSmee 和 Su 


fetch = +refs/nheadqs/x* :refs/remotes/Jjduery/r 


二 LU 


这 个 [remote "origin"] 区 段 的 设 定 ， 包 含 了 逐 ; 
储存 库 的 代表 名 称 origin， 还 有 两 个 重要 的 参 
数 ， 分 别 是 url 与 fetch 这 两 个 ， 所 代表 的 意思 

是 : “这 端 储存 库 URL 位 址 

在 httpbs://github.com/doggy8088/sandbox-empty2.g9it 
然后 fetch 所 指定 的 则 是 一 个 参照 名 称 对 应 规格 
(refSspec)。 ) 


何谓 参照 名 称 对 应 规格 (refspec) 


我 们 先 来 看 一 下 refspec 的 格式 : 


+Trefs/nheadqs/ :refs/remotes/oridiny/r* 


这 个 格式 概略 区 分 成 4 块 : 


设 定 + 加 号 ， 代 表 传 输 资 料 时 ， 不 会 特别 使 用 
安全 性 确认 机 制 。 


refs/heaadqsy/r 
来源 参 照 规 格 ， ， 代 表 一 个 位 於 让 端 储存 库 


的 让 端 分 支 ， 而 >* 星 号 代表 refs/heads/ 这 
个 路 径 下 5 所 有 的 退 端 参照 ，。 


这 用 来 区 隔 5 来 源 分 支 J 与 ' 目的 分 支 ， 
。 Tefs/remotes/originyr 


-目的 参照 规格 ，， 代 表 一 个 位 於 本 地 储存 库 
的 本 地 追 跳 分 支 ， 而 * 星 号 代表 工作 目 公 

的 refs/remotes/originy/ 这 个 路 径 下 I 所 有 
的 本 地 参照 ，。 


当 我 们 定义 好 这 份 refspec 对 应 规格 和 后， 主要 会 影 


设 到 的 是 djit fetch 盟 9jit Push 这 两 个 这 Y 省 储存 


库 的 操作 。 


git fetch 就 是 把 下 端 储存 库 的 相关 物件 取 回 ， 但 
要 取得 那些 下 端 分 支 的 物件 呢 ? 惑 是 和 过 圳 份 
refspec 的 定义 ， 他 才 知道 的 。 以 上 述 为 例 ， 当 你 执 
行 git fetch 或 git fetch origin 的 时 候 ， 他 会 
先 透 过 URL 右 到 踪 端 储存 库 ， 然 后 找 出 “来 源 参照 
规格 , 的 那些 舟 端 分 支 (refs/heads/ 刀 j， 取 回 之 后 
放 入 “目的 参照 规格 , 的 那些 本 地 追 跳 分 支 


(refs/remotes/origin/rx)。 


我 们 要 怎样 但 询 这 端 储存 库 到 底 有 哪些 分 文 呢 ? 你 
可 以 执行 git 1s-remote 
或 gjit 1s-remote oridcin 即 可 列 出 所 有 各 端 分 


:N\sandbox-empty2>9it 1s-Femote orFigin 
?686e 2 直人 92 3 和 | HEhD 


96998?78hbfc5896a82609629e5c944873fca2c5?75 Fefs-heads-TestBranch 
机 hefs-Aheads/mastekr 


如 果 你 把 fetch 的 refspec 修改 成 以 下 这 样 ， 那 么 除 
了 masteL 以 外 的 束 端 分 支 7 就 不 会 被 下 载 了 ! 


fetch = +refs/nheads/master:Trefs/remotes/originy/ym 


如 果 你 想 明 确 下 载 特定 继 个 分 支 就 好 ， 你 可 以 重复 
定义 好 和 伙 个 不 同 的 fetch 参照 规格 (refspec)， 例 
如 : 


[zemote "originy"] 


三 汪 忆 DIS 0 人 eu ecomiaeogy8b8sSyanadbo 


fetch = +refs/heads/master:refs/rempbtes/o 


fetch = +refs/heads/TestBranchnh :refs/remcot 


另外 ， 在 我 们 透 过 9it remote adqdq [URTLI] 建立 踪 
端 储存 库 设 定时 ， 半 没有 push 参照 规格 ， 其 预 设 
值 如 下 : 


Pushnh = +refs/headqs/x* :refs/headsy/* 


所 代表 的 意思 则 是 ， 沼 执行 sit push 时 ，Git 指令 
会 参考 这 份 push 的 参照 规格 ， 让 你 将 本 地 储存 库 
在 refs/heads/* 底下 的 所 有 分 支 与 标 敏 ， 全 部 都 
推送 到 相 针 应 带 端 储存 库 的 refs/heads/* 参照 名 


称 下 。 


最 后 / 无 论 你 执行 GIL push 或 gjit fetch ， 在 不 
特别 加 参数 的 情况 下 ，Git 预 设 就 是 用 origin 当成 
踪 端 储存 库 ， 下 使 用 orisgin 的 参照 规格 。 


本 地 分 文 与 还 端 储存 库 之 间 的 关 休 


我 们 已 经 知道 ， 一 个 工作 目 凶 下 的 本 地 储存 库 ， 可 
能 会 定义 有 多 个 下 端 储存 库 。 所 以 当 你 想 将 
mastezr 分 支 透 过 it push 推送 到 下 端 时 ，GGit 


能 不 知道 你 到 拱 想 推送 到 哪里 ， 所 以 我 们 要 另外 
> 文 与 这 端 储存 库 之 问 的 关 他 。 


我 们 

以 https://github.com/doggy8088/frontendq-tools .gdgit 

这 个 下端 储存 库 为 例 ， 我 复 抠 下 来 后 ， 预 设 就 会 有 

一 个 master 本 地 分 > 支 ， 

个 FixForcRLE 本 地 分 支 ， 直 接 透 过 ait push 扰 

法 推送 成 功 ， 你 必须 输入 完整 

的 sit push origin FixEorcRLE 指令 才能 将 本 地 
的 ,原因 就 出 在 你 下 没有 设 定 本 地 分 

文生 '" 有 束 端 储存 库 ， 之 问 的 预 设 对 应 。 


:fontend-tools>git hbranch 一 a 


mastek 
-> okFiginAmaster 


:\frontend-tools>git push 
Eatal: The cukrent branch PixForCRLEF has no upsthkeam branch - 
D_ push the cuFFent branch and set the Femote as Upstheam。 USe 


9it push --sSet-upstrkeam okFkigqin PixForCRLP 


:fkontend-tools>git push origin FixForCRLF 
Sekrname foFr httpbs:--githuhb-com': doggyv86888 


assSwokd for "https:-doggyv8988Begithupb .com'” : 

ounting ohbjects: 5。done - 
IDpelta compFression using up to 4 threads - 

ompkessing ohbjects: 109x 《3-3>。 done -. 

Jriting ohbjects: 1009X 〈3/3>。2-43 KiB 1 0 hvtes/S。done- 
otal 3〈delta 1>。hFeused 9 《delta D) 

DO httpbs:--9github .com/doggy8988-fhrontend-too1s 

关 [new hbranch] FixForCRLF -> FixForCRLF 


:\frkontend-tools>git branch 一 a 
mastekr 


->okiginymastekr 


:NEfkontend-tools>git push 
Eatal: The curhent branch FixForCRLEF has no upstheam branch - 
0 push the cukFkent branch and Set the Femote as UpStheam。 USe 


9it push XForCRLF 


要 将 本 地 分 支 建立 起 跟 带 端 储存 库 的 对 应 关 休 ， 只 
要 在 9it Pusnh 的 时 候 加 上 --set-upstream 参 
数 ， 即 可 将 本 地 分 支 主 册 进 .sit\config 设 定 档 ， 
之 后 再 用 sit push 就 可 以 顺利 的 自动 推送 上 去 。 


:frontend-tools>gqit push 一 t-upstFream origin PixForCRLPF 

Sekname forkr ”http Agithupb .com doggyv8D88 

asswokd for :https:- [doggy80988@githupb com' : 

Branch FixForCRLF set up to track remote branch FixForCRLF from origin - 
IEvueruvthing up-to-date 


:Ntfrontend-tools>gqit push 

Sekname for "http Agithub -com' : doggy8988 
asswokd for 'https:-[doggy8988@githupb -com' : 
IEvueruvthing up-to-date 


行 9it Push --sSet-upstream origin ERIXEOFCRTE 


的 同时 ,会 在 .gitN\confid 设 定 档 增 加 以 下 内 容 : 


GoRROEGRTNPRY 
zemote = Origin 


mecge = Tefs/heads/EFIXEorCRLE 


你 可 以 从 这 个 设 定 档 的 格式 中 发 现 ， 在 这 

个 [branch "FixForcRLE"] 设 定 里 面 ， 有 两 个 属 
性 分 别 是 remote 熏 merge， 所 代表 的 意思 是 : 
当 你 想 要 将 本 地 的 FixForcRLF 分 支 推送 到 乏 端 
储存 库 时 ， 预 设 的 让 端 储存 库 为 orisin 这 个 ， 然 
后 推送 的 时 候 要 将 本 次 的 变更 合 侍 


到 | refs/heads/EFixFEorCRLE 这 个 下端 分 支 壬 。 ] 


当然 ， 我 们 在 一 开始 执 

行 Sit clone https://github.com/doggqy8088/frontena 
的 时 候 ，Git 就 会 预 设 攻 我 们 建立 好 master 分 支 的 
对 座 关 休 ， 所 以 针对 master 分 支 进行 操作 时 ， 不 

需要 额外 加 上 --set- -upstzream 就 能 使 用 。 其 其 分 支 

的 定义 内 容 如 下 : 


[pranch "master"] 


zemote = Origin 

merdgde = frefs/headqs/masteL 
个、 十 
今日 小 编 


本 篇 文章 详细 的 介绍 ， 在 面 对 带 端 储存 库 时 的 一 些 
重要 观念 ， 尤 其 是 参照 规格 (refspec) 这 一 段 ,学 会 
之 后 才 有 机 会 设 定 更 加 符合 自己 或 转 队 需要 的 设 

定 。 不 过 ， 还 是 建议 大 家 不 要 修改 预 设 值 ， 以 免 把 
大 家 搞 糊 泛 了 。 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git remote -V 


git branch -f 
。git branch -a 


git branch 
。 git push 


git ls-remote 


。 HOME 
。 回 目 色 


前 


下 


使 用 GitHub 让 端 储存 库 - 入 门 篇 
多 人 在 同一 个 让 端 储存 库 中 进行 版 控 


二 
二 类， 


第 26 天 : 多 人 在 同一 伯 未 端 
储存 库 中 进行 版 控 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/26.md 


一 个 人 用 的 版 本 控 管 ， 只 能 算是 当 作 原始 码 压 史 人 备 
份 工 具 ， 在 大 多 数 的 情况 下 ， 版 本 控 管 机 制 都 是 设 
计 给 多 人 共同 使 用 的 ， 尤 其 是 Git 这 套 分 散 式 版 本 
控 管 系统 ， 更 是 设计 给 成 王 上 万 人 都 能 顺利 使 用 的 
版 本 控 管 工具 。 不 过 ， 在 多 人 使 用 的 情境 下 ， 通 常 
多 多 少 少 也 会 带 来 一 些 副作用 ， 多 跟 少 的 问题 。 在 
Git 版 控 中 ， 多 人 同时 进行 版 控 的 策略 有 好 拓 种 ， 今 
天 将 介绍 大 家 共用 一 个 这 端 储存 库 的 使 用 方式 与 问 
题解 决 方法 。 


建立 多 人 使 用 的 过 端 储存 库 与 工作 目 色 


我 们 先 假设 所 有 人 只 会 共用 一 个 踪 端 储存 库 ，， 
由 於 大 家 会 用 sit clone 指令 把 束 端 储存 库 给 复 移 
回来 ， 所 以 每 个 人 都 会 有 一 份 所 有 完整 历史 的 版 本 


库 。 


为 了 简化 讲解 ， 我 先 在 本 地 先 建立 一 个 5 共用 储存 
库 ， ， 把 它 当 成 下端 储存 库 , 来 用 ， 其 用 法 跟 你 
在 用 GitHub 的 时 候 一 模 一 样 ， 不 但 观念 一 样 ， 指 
令 操 作 也 都 完全 相同 。 我 们 先 用 以 下 指令 建立 一 个 
共用 储存 物 ， 下 位 於 c:/myproject.git 资料 来 
下 : 


GS 

ON 

mkKdaas moceajeceesoOme 
人 国王 人 相生 CC 七 到 打工 长 


RE 


再 来 我 们 假设 有 两 位 开发 人 员 准 全 开发 一 个 新 专 


案 myProJject ， 分别 是 USseLrI 与 UseLr2 这 两 位 。 


首先 ，Userl 先 利 

用 g9it clone C:/mypPproject .dit UserlWD 建立 一 
个 工作 目录 ， 焉 在 工作 目录 下 建立 一 个 初始 版 本 ， 
亚 推 送 到 orisin 表 端 储存 库 。 其 指令 如 下 : 


GE 
GEN 

9jit clone C:/myproject .9g9it User1LWD 
cq User1LWD 

ECTaE > 七 区 七 

GE EGR 

有 EEC 人 刘 玫 二 EN 


ES 要 Tagamn 有 maistem 


现在 我 们 的 下 问 储 存 库 C:/mypProject .dijt 已 经 有 
了 一 个 初始 版 本 ， 邯 扒 有 一 个 a.txt 档案 。 


接著 FUSSE2 利 

用 ait clone Cc:/myproject .9 让 t User2WD 建立 另 
一 个 属於 user2 自己 的 工作 目录 ， 预 设 会 自动 建立 
好 orisin 还 端 储存 库 的 设 定 。 其 指令 如 下 : 


人 
CGqN 

9jijit clone C:/myproject .9it User2WD 
cq User2WD 


现在 我 们 已 经 准备 好 一 个 "多 人 , (两 人 ) 使 用 的 版 
控 环 境 ， 下 共用 一 个 这 端 储存 库 。 


束 问 储存 库 的 基本 开发 帝 程 


现在 userl 与 user2 所 有 完全 相同 的 储存 库 ， 版 
本 也 都 完全 一 样 ， 都 只 有 一 个 。 


现在 userl 先 声 奢 人 ， 擒 先 建立 了 版 本 ， 而 且 也 将 
弧 更 推送 到 c: /myproject .9it 表 端 储存 库 : 


RINGSE 和 MD OA ELIORNESOE 


SRNUSSETWDEZSHREESSOEE 


GeNUSEETNWDOTECEGmmat 攻 三 人 全 记 太 可 G 居 四 贡 攻 Ze 
IasktececeocUsilNaadeo 遇 全文 世 
国标 


Create moaqe 100644 pb .七 Xt 


CNUWS 荆 下 下 人 电 过 本 本 局 可 SS 有 证 人 二 GT 本 人 二 二 到 
Countind objects: 4，dqone. 
Delta _ compression using up to 4 threadas . 
Compressind objects: 100g (2/2)，dqone . 
WETEonoEobaecEs 005 六 2) 克 267 YEes 0 bytes 
Total 3 (qdqelta 0)，treusedq 0 (qdqelta 0) 
ROGERE 

下 427bcoce0Snastes 本 三 关 站 mas 世人 六 


这 时 User2 人 一 个 是 本 地 
的 master 分 支 ， 另 一 个 是 Origin/masteL 本 地 追 
跳 分 支 。 但 是 user2 0 origin/master 亚 没 
有 得 到 这 端 储存 库 的 最 新 版 ， 而 且 user2 站 不 知 
道 userl 已 经 将 他 手 超 的 版 本 推送 到 带 端 储存 库 
了 ， 所 以 还 是 继续 自己 的 开发 作业 ， 也 在 他 上 自己 的 
工作 目 人 录 中 建立 了 一 个 版 本 。 但 在 准备 将 版 本 推送 
到 这 端 储存 库 时 ， 发 现 了 一 个 问题 ， 因 为 他 的 推送 
作业 被 带 端 储存 库 拒 绝 了 ! 原因 就 出 在 存在 於 乏 端 
储存 库 的 初始 版 本 之 后 ， 已 经 扒 有 了 一 个 新 版 本 ， 
他 不 允许 另外 一 个 人 建立 一 个 多 重 的 版 本 夺 史 ， 所 
以 拒绝 你 将 本 地 版 本 推送 上 去 。 


GONUSEE2NWD>SENOE CE 到 汪 世 到 上 
GONUSENWDEGnEEE SGa 


GENUSESTEZNWD>>gu 硬 ECmimait 二 放晴 风 六 局 基 公演 二 六 攻 
[masterc qdqbebba3] Adadq c .七 X 七 
二 “二 人 有 EU 由 了 工 SeEESTTE) 


create moaqe 100644 c.txXt 


CEINUSSE 有 W 加 六 g 相 本 启 可 SS 用 王 忆 下 工本 TaS 志 S 歼 
IRONoSoEGERCILE 


! [rejected] master -> master (fetch 工 IT 


error: failedq to Push some refs to '"C:/myproJject 


Pint: Upadates Were Lirejected because the Leimote ct 


anmenoehnhawe 有 Loca assnals carsedq 5 
hint: to the Same ref. You may Want 七 DO first me 
an ELITEBEEOEe EDSnanao aoann 


hint: See the 'Note about fast-forwarads' in "gjit 


UserTWD xi User2WD X 


4 File Status All Branchss Show Remete Branches Date Order * 
罗 Werking Copy Graph Description 
4 Branches 四 | 宇 mastsr 国 加 可 Add cbdt 
党 master 国 [ 束 symaster][ 训 CORESDIEEEEZ 
Tags 
4 Remotes 
4 旺 origin 
有 HEAD 
ESD 


到 这 种 问题 请 不 要 紧张 ，Git 很 擅长 处 里 这 种 状 
况 。 你 (user2) 现在 要 做 的 事 ， 就 是 先 把 下端 储 存 
库 中 的 新 物件 取 回 ， 如 下 指令 : 


C:N\User2WD>dgit fetch 
remote: Counting objects: 4，dqone . 
remote: Compressind objects: 100g (2/2)，qone . 
zemote: ITotal 3 (aelta 0)，FzeuseaQ 0 (aeltal 0 ) 
Unpackind objects: 100gs (3/3)，dqone . 
Erzom C:/myProJject 

本 4 故国 到 SOCoS0OS5RRRTmSESIEEE -> origin/masteL 


| UserlWD xl User2wD X 


4 File Status | Al Branchess Show Remecte Branches 。” Date Order v 
的 Working copy Graph Description 
4 Branches [多 master 攻 Add c.txt 
人 master GE 车 Smaste | 节 oigyHERD]Add bt 
Tags 
4 Remotes 
4 昌 origin 
对 HEAD 
要 master 


这 时 我 们 可 以 看 到 user2wp 中 origqin/master 这 

个 本 地 追 跳 分 支 的 的 版 本 线 图 ， 已 经 移动 了 一 个 版 

本 ， 这 代表 你 已 经 成 功 改 释 了 origin/master 的 参 
照 位 址 到 最 新 的 aaa b.txt 这 个 版 本 。 


现在 你 要 做 的 则 是 把 origin/master 版 本 的 释 
[ 合 儒 J 回 自己 的 master 本 地 分 支 : 


C:NXUser2WNWD>dit merge origin/masteL 
Merde madqde by the "recursive' Stratedy . 
RE 广 辣 避 | 全 
1 file changdedq，1 insertion (+) 


Create moaqe 100644 pb. 七 Xt 


| XI User2WD X | 


4 File Status All Branches Show Remote Branches “Date Order 
的 working copy Graph Description 
4 Branches 四 ER: head Mergeremote-tracking branch 'originymaster 
Add ct 
Tags 芭 originymaster][ 敬 origin/HEAD]Add bbt 
2 Remotes Add atxt 
4 星 origin 
有 登 HEAD 
有 滞 master 


这 样 你 就 可 以 将 带 端 储存 库 中 master 踪 端 分 支 的 
所 有 版 本 套用 到 自己 的 master 分 支 上 ， 也 代表 你 
现在 可 以 党 试 把 本 地 修改 过 的 继 更 版 本 推送 到 和 吕 端 
储存 库 了 。 


GENUSssne2ND>ognEEUshEOcTOmEEmSSEE 下 

Countclnog opJects yy QQone 

Delta _ compression using up to 4 threadas . 
Compressind objects: 100g (4/4)，dqone . 

Writing objects: 100g% (5/5)，566 bytes | 0 bytes 
Total 5 (aqelta 0)，treusedq 0 (aqelta 0) 

JR 人 ANWo2coiSEERCPE 


7Vbcbc05..32ef41l1c master 一 > maste 


| 上 网 ucwp x 


4 File Status AllBmanches v。 回 showRemoteBranches Dateorder v 
加 Working copy Graph Description 
4 Branches [ 罕 masterTTTTT 
罕 master 
Tags Addbtdk 
RE Add atbdt 
4 旺 origin 
守 HEAD 
二 master 


如 果 这 个 时 候 user2 又 再 度 做 出 继 更 ， 而 且 user1 
也 不 知道 原来 user2 也 送出 了 一 些 变 更 到 踪 端 储存 
库 (在 分 散 式 的 版 本 控 管 系统 中 ， 过 种 状 沈 很 常 

见 ， 音 竟 入 家 亚 没有 坐 在 同一 癌 办 公 宇 ) ， 而 又 建立 
了 一 个 版 本 ， 当 然 他 也 扰 法 成 功 的 把 变更 推送 上 
到 5 


GANRUSSETHNWD>SENGQ 关 之 硬 可 二 蕊 到 巧 


GONUSEETEWDEGmE SO 


GERNRUSSTETWD:gaeEEeCmimiaiie 三 本 岂 六 OO 大 本 志文 可 
[mastexc 57ea603] Add qdq. 七 Xt 
1 file changedq，1 insertion (+) 


create moaqe 100644 dq.txXt 


此 时 useri 该 做 的 事 ， 其 实 跟 刚 刚 user2 做 的 事 
一 模 一 柑 ， 也 是 要 先 用 sit fetch 取 回 踪 端 储存 库 
中 的 最 新 版 ， 然 后 再 用 ait merge origin/master 
合 儒 回 自己 的 master 本 地 分 最 后 再 

用 sit push 推送 进 踪 端 储存 库 。 不 过 ， 这 次 我 们 
改 用 sit pull 指令 晶 我 们 一 次 做 到 sit fetch 
盟 ait merge origdin/mastez 这 个 动作 ， 这 动作 


相 针 的 会 简单 很 多 。 


CRRNUSEEEHNWD 之 HTEE 记 Di 

Merde madqde by the "recursive"' Stratedy . 
SETLEE 
1 file changedq，1 insertion (+) 


create moaqe 100644 c.tXt 


User1WD X 加 ser2WD X 


4 file Status All Branches Y Show Remcte Branches ”Date Order v 
的 Working copy Graph Description 
4 Branches 加 Merge branch 'master of CVYmyproject 
侣 master 
Tags 
4 Remotes 
4 到 origin 
家 master 


最 和 后 我 们 用 9it Push oridin masteLr 把 版 本 给 


推送 到 踪 端 储存 库 : 


C:NXUser1LNWD>dgit Push origin masteL 
CounenogEobJecEe oOcnee 

Delta_ compression using up to 4 上 threads . 
Compressind objects: 100gs (4/4)，dqone . 
WEinndqESSECSEEERETUUO 257EES 下 大 Ubytes 
Total 5 (aqelta 2)，reusedq 0 (aqelta 0) 

下 重合 和 DOECECERGOaE 


32ef41c..1ae28dqb master -> masteL 


| User2WD XI| User1WD X 


4 File Status All Branches v 园 Show Remoete Branchss DateOrder “ 
人 Working copy Graph Description 
4 Branches 下 有 敬 originymaster 史 master]L ET 于 
add N 
Tags Merge remote-tracking branch 'origin/master 
4 Remotes Addcbt 
4 星 origin Add bbd 
有 master Add atbt 


就 这 样 不 断 周而复始 ， 完 成 多 人 协同 作业 的 步 灵 。 


今 今日 小 颖 


无 法 避免 的 ， 在 执行 git merge origin/master 

或 sit pull 的 过 程 中 ， 还 是 很 有 可 能 会 出 现 合 供 
征 突 的 现象 ， 遇 到 这 种 情形 你 还 是 必须 手动 处 里 范 
协调 解决 秆 突 ， 但 这 已 经 是 多 人 使 用 Git 版 本 控 管 
中 最 简单 的 使 用 方式 。 


如 果 你 今天 发 生 了 种 突 状况 ， 而 又 不 知道 如 何 解 
决 ， 因 为 版 本 尚未 被 成 功 合 伴 ， 所 以 你 可 以 执行 以 
下 指令 上“ 重 置 , 到 目前 的 aap 版 本 : 


dit reset --hardq HEAD 


如 果 你 今天 成 功 的 合 任 了 ， 但 又 想 反 悔 这 次 的 合 供 
动作 ， 那 床 你 还 是 可 以 执行 以 下 指令 “ 重 置 , 到 合 
儒 前 的 版 本 状态 ， 也 就 是 重 置 到 oRIc_Hap 这 个 版 
本 、 


9it reset --harq ORIG_HEAD 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git init --bare 


git clone [repo_url] [din] 
。 git add . 
git commit -m "message" 


git push origin master 
。 git fetch 


git merge origin/master 

。 git pull 

git reset --hard HEAD 

。git reset --hard ORIG_HEAD 


*。 HOME 
。 回 目 色 


。 前 一 天 : 使 用 GitHub 还 端 储存 库 - 观念 篇 
。 下 一 天 : 透 过 分 支 在 同一 个 踪 端 储存 库 中 进行 
版 控 


第 27 大 : 天 过 分 支 在 同一 个 
束 刀 储 人 存 库 中 进行 版 控 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/27.md 


如 果 在 公司 内 部 只 有 一 个 共用 的 Git 壕 端 储存 库 ， 
大 家 都 有 存 取 权 限 的 情况 下 ， 可 能 会 遇 到 一 些 协 同 
作业 上 的 问题 ， 那 就 是 不 同人 彼此 之 间 的 程式 码 互 
相干 摄 的 情况 。 例 如 你 在 转 队 开发 的 过 程 中 ， 被 指 
派 负责 开发 新 功能 ， 但 同时 间 其 他 同事 负责 修正 目 
前 上 线 的 程式 错误 ， 如 果 两 人 共用 同一 个 分 支 ( 例 
如 master 分 支 )， 那 床 在 版 控 的 过 程 中 就 很 容易 发 
生 征 突 的 情况 ， 这 时 你 克 该 要 善 加 利用 分 支 将 不 同 
用 途 的 原始 码 分 别 进 行 版 本 管理 。 


建立 多 人 使 用 的 还 端 储存 库 与 工作 目 色 


我 在 GitHub 上 建立 了 一 个 sandbox-multi-branch 
专案 ， 站 直接 在 GitHub 上 建立 一 个 Initial commit 
版 本 ， 用 做 本 篇 文章 的 下端 储 存 康 。 但 这 次 我 改 


用 ee 
这 个 网 址 ， 透 过 SSH 通讯 协定 来 存 取 我 的 束 端 储 

存 库 ， 时 用 二 欠 执 行 这 端 储存 库 的 操作 

时 都 要 输入 帐号 密码 。 


5 败 etwork 


吧 Settings 


SSH 2 


全 


You can clone with HTTPS， 
SSH,|er Supversion 他 


中 


团 Clone in Desktop 
SP 


Download ZIP 
我 们 执行 以 下 指令 将 专案 复 抱 回 来 : 


C:N\>dit clone ditegithub.com:dqogdgqy8088/sanaQbox-m 
Commontec SangboG 基 二 而 让 下 地 基 旺 商人 hi 天 天 天 

Receliving objecg objects: 3，dqone.Receiving obJje 
Receliving objects: 100$50)， reused 0 (aqeltal 0)ts : 
Receivind objects: 100g (3/3)，dqone . 


C:\>cdq sandbox=multi=branch 


Ganaoox=nmialieT anmchoacR CS 

Commit 6eeee883275e3d5e0281767aca4f456dq952fa682 
Author: Will 保 哥 <xxxQeQgmail.com> 

Date : SOOGNE 本 多 0 


SEE 本 ia 
C:N\sandbox-multi-branch>dit branch 一 a 
x ImasteL 


remotes/oridin/VHEAD -> origin/masteL 


Femotes/oridin/masteL 


此 时 我 们 的 -全 NEGnEIG 内 容 如 下 : 


[core] 
zepositoryformatvVezrsion = 0 
filemodqde = false 


bare = false 

LogallLrefupdqates = 七 YUe 

SyYmlLinks = false 

1gnorecase = 七 YUe 

hideDotEiles = QotGitoOon1LyY 

[zemote "originy"] 

Url = g9itaQd9ithub .com:dqodgdgqy8088/sandqbox-multI-br， 


fetch = +trefs/headqs/* :refs/remotes/oridginyr 


oanmeanavmnastese 
zemote = Origin 


merdge = fefs/headqs/masteL 


单 见 的 分 支 名 称 


我 们 知道 在 建立 好 一 个 新 的 Git 储存 库 时 ， 预 设 都 
会 有 一 个 master 分 文 。 在 实务 上 ， 这 仙 分 支 通常 
用 来 当 作 目前 系统 的 “ 称 定 版 本 ， ， 也 就 是 这 仙 版 
本 必须 是 乾 潭 且 高 品质 的 原始 码 版 本 。 所 以 ， 我 们 
会 要 求 所 有 人 都 不 要 用 这 个 分 支 来 建立 任何 版 本 ， 
真正 要 建立 版 本 时 ， 一 定 会 透 过 ' 合 供 , 的 方式 来 
进行 操作 ， 以 确保 版 本 能 弧 更 容易 被 追 跳 。 


进入 开发 阶段 时 ， 我 们 通常 会 再 从 master 分 支 建 
立 起 另 一 个 aevelop 分 文 ， 用 来 作为 “开发 分 

支 ! ， 也 就 是 所 有 人 都 会 在 这 个 分 支 上 进行 开发 ， 
但 这 个 时 候 或 许 会 彦 生 一 些 种 突 的 情形 ， 因 为 大 家 
都 在 同一 个 分 支 上 进行 版 本 控 管 。 不 过 这 种 用 法 跟 
以 往 我 们 用 Subversion 的 时 候 是 比较 类 似 的 ， 所 以 
使 用 上 的 观念 通常 差不多 。 本 文 稍 后 就 会 介绍 一 些 
分 支 开 发 的 练 避 ， 但 我 们 现在 就 可 以 先 建立 一 

个 QqeveoPp 分 文 起 来 。 


C:N\sandbox-multi-branch>dit branch 


Ta SEE 和 


C:N\sandbox-multi-branch>dit checkout -b aqeve1Lop 


Switchedq to a new branch "qqevelLopy' 


GONSEUReloeesnheosEIECEEIe2ERien 
* QqevelLop 


masteL 


开发 过 程 中 ， 有 时 候 我 们 也 会 因为 需求 更 ， 而 被 

指派 开发 一 些 新 功能 ， 但 这 些 新 功能 可 能 变动 性 逮 

很 大 ， 甚 至 只 是 想 进 行 PocC 验证 而 开发 的 小 功能 。 

这 些小 功能 只 是 测试 用 途 ， 你 不 想 因为 开发 这 些 测 

试 功能 而 影响 到 大 家 的 开发 作业 ， 所 以 这 时 我 们 会 

选择 再 建立 起 一 个 新 功能 分 文 : ， 专 门 用 来 存放 

这 些 新 增 功能 的 程式 码 版 本 。 这 个 测试 用 的 “功能 
分 支 ， ， 通 常会 建立 在 aevelop 之 上 “， 所 以 我 们 会 
再 从 aevelop 分 支 来 建立 另 一 个 分 文 。 但 这 个 分 支 
的 名 称 ， 实 务 上 通常 会 取 名 


汶 feature/ [branch_name] ， 例 


如 feature/aspnet_ idqentityo 


GANSsanagox=mult=boraneh>onicepranchn 


* QqevelLop 


masteL 


CNsandoox=multi=-branch>ogit Checkout =D fehture/ 


Switched to a new branch 'feature/aspnet_ idqentit 


NSEUReloeesDeEosEIECTTEEIe2ERien 
QeveoP 
xx feature/aspnet_ idqentity 


masteL 


如 果 你 发 现在 开发 的 过 程 中 ， 上 正式 机 ,，( 生 彦 环 
境 ) 的 系统 出 现 了 一 个 严重 错误 ， 但 在 避 
支 4 里 又 包含 一 些 尚 未 完成 的 功能 ， 这 时 你 可 

和 从 mastez 分 支 紧急 建立 一 个 上 修正 分 ee 
的 命名 为 hotfix/[branch_namel]， 例 


如 ` hotfix/pbudgds_ in membershipo。 


GoNSaTDaBoXEmUOlit 二 的 荆 3ERomcEeEanchn 
QeveoP 
x feature/aspnet_ idqentity 


masteL 


C:N\sandqbox-multi-branch>dgit checkout masteL 上 


Switchedq to pranch 'masteLc ' 


C:N\sandbox-multi-branch>dit branch 
QeveoP 
feature/aspnet_ idqentity 


x ImasteL 


GANREEiielgeosERNEESeREEOIONECREEIGINSEISOEIE oO 号 员 榴 :he 


Switched to a new branch "hotfix/pbugds_ in members: 


C:N\sandbox-multi-branch>dit branch 
QeveoPp 
feature/aspnet_ idqentity 

x hotfix/pbugds_ in membership 


masteL 


如 果 你 发 现 目前 的 master 分 支 赵 於 称 定 版 本 ， 那 

育 你 可 能 会 想 蔡 目 前 的 master 分 支 建立 起 一 个 

- 标 毓 物 件 ， 或 称 ' 标示 标 敏 ， (annotated tag) ， 

那 床 你 可 以 先 切换 到 master 分 支 合 输 

入 git tag 1.0.0-betal -a -m "V1.0.0-betal createc 
即 可 建立 一 个 名 为 1.0.0-beta 的 标示 标 敏 ， 存 透 

过 -m 赋予 标 毓 一 个 说 明 讯息 。 


C:N\sandbox-multi-branch>dit branch 


QeveoPp 
feature/aspnet_ idqentity 
x hotfix/pbugs_ in membership 


masteL 


CNsandbox=multi=-branch>oglit checkout mastet 


Switchedq to pranch 'masteLc' 


C:N\sandbox-multi-branch>dit tag 1.0.0-betal 


CNsanadbox=multi=-branmch>oglt 七 a9 
二 Sea 


以 上 就 是 使 用 Git 的 过 程 中 常见 的 命名 规则 与 版 控 


沅 程 。 


将 本 地 分 文 送 上 束 山 储存 库 


目前 为 止 我 们 建立 了 好 估 个 分 支 与 标 敏 ， 用 
SourceTree 来 看 ， 目 前 还 看 不 出 分 支 的 版 本 线 图 ， 
输 竟 我 们 还 洛 有 建立 任何 版 本 ， 但 该 有 的 分 支 已 经 
被 成 功 建立 ， 如 下 图 示 : 


sandbox-multi-branch X 


4 File Status All Branches “ Show Remote Branches 。” Date Order 
网 Working Copy Graph 
4 Branches 2 
有 量 develop 
4 于) feature 
尝 aspnet_identity 
4 型 ;hotfix 
党 bugs in_membership 
4 Tags 
入 1.00-betal 人 
4 Remotes 
4 星 origin 
HEAD 
于 master | 


不 过 ， 这 些 分 支 都 俊 储 存在 本 地 储存 库 中 ， 转 队 中 
所 有 其 他 人 都 无 法 得 到 你 建立 的 这 些 分 支 ， 如 果 要 
将 这 些 分 支 的 参照 名 称 推送 到 还 端 储存 库 ， 可 以 使 


用 ait push --all 这 个 指令 。 


GeNssana5oxzmontaESE3nESN 过 SIE 本 记 责 Sn 三 三 天， 
Total 0 (aqelta 0)，treusedq 0 (aqelta 0) 
To g9itaegithub.com:doggvy8088/sandbox-multi-pranch 


* [new pranch] QqevelLop -> qdqevelLop 
* [new branch] feature/aspnet_ iaqentity 一 > 
* [new branch] hotfix/pbugs_ in membership 一 


不 过 如 果 只 下 过 --all 参数 是 不 级 的 ， 可 能 还 要 加 
上 --tags 参数 ， 才 能 将 标示 标 毓 也 一 儒 推 送 到 过 
端 储存 库 。 


CNsandbox=multi=-branch>oglit Push ==tags 

ee 

WaiEamTigEobaeceEsR 下 00 二 全 必 休 由 三 bXEeS 0| pytes 

Total 1 (aqelta 0)，treusedq 0 (dqelta 0) 

To gitagithub.com:doggvy8088/sandqbox=-multi-branch 
* [new tad] 1.0.0=-pbetal =-> 1.0.0=petal 


这 个 时 候 ， 所 有 物件 与 参照 名 称 都 已 经 储存 在 舟 端 
储存 库 了 。 我 们 连 到 GitHub 就 能 看 到 这 些 物件 已 
经 可 以 被 浏 览 到 : 


| doggy8088 / sandbox-multi-branch 


Description Website 
Short description of this repository Website forthis rer 


1commit 4 branches 1 reiease 


Yourrecently pushed branches 
?Photfix/bugs_ in_ membership (2 minutes ago) 
mp featurefaspnet identity (2 minutes ago) 
?develop (2 minutes ago) 


Rbranchs master < | sandbox-muiti-branch / 
aa | 
上 


慌 
Switch branchesjitags 


Initial 


思 d Find or create a branch 


Branches 


坟 develop 


featurelaspnet_identity 


hot 怕 xbpugs_in_membership 


anch 


4 ww master 


如 果 切 换 到 Tags 页 敏 的 话 ， 也 可 以 看 到 标 敏 物件 
也 被 送 上 来 了 : 


天 Paranch master= sandbox-multi-branch / 白 


Switch branchesitags 
Initial 


思 。 
日 下 
Branches 


改 10.0-beta1 
FREETRETTTC 


思 | 


请 围 队 成 员 下 载 带 峭 储 存 库 所 有 物件 


这 个 时 候 大 家 就 能 狗 透 
过 sit fetch --all --tags 将 所 有 物件 取 回 ， 包 
含 所 有 物件 参照 与 标 毓 参照 


MO 


我 们 建立 起 另 一 个 工作 目录 ， 模 气 其 他 使 用 者 取 回 
资料 的 情况 : 


C:N\>dit clone ditegithub.com:dqogdgqy8088/sanQbox-m 
Gilicningineoasanodleox=mulitaotsanchEseT2UR 
remote: Counting objects: 4，dqone . 

remote: Compressind objects: 100g (2/2)，qone . 
zemote: Total 4 (aqelta 0)，treuseaq 1 (aqelta 0) 
Receivind objects: 100gs (4/4)，dqone . 


C:N\>cd sandbox-multi-branch-use2 


C:N\sandbox-multi-branch-user2>dit fetch 日 


Eetching origin 


取 回 物件 和 后， 用 SourceTree 查看 储存 计 的 状态 如 
下 : 


|| sandbox-mult-branch 又 sandbox-multi-branch-user2 X 


| 4 File Status 
罗 0 Working copy 


|4 Branches 


4 Tags SN 


All Branches Y [Vshow Remote Branches Date Order 
Graph 


军 aspnet_identity 
4 训 ; hotfix 
妥 bugs in_membership 
好 master 


开始 各 目 进 行 不 同 的 分 文 开 发 


现在 开始 ， 围 队 所 有 成 遇 都 所有 了 预先 定义 好 的 
rGit 储存 库 范 本 ，， 大 家 就 能 各 就 各 位 ， 开 发 自己 
需要 开发 的 功能 。 或 许 会 有 两 个 人 在 develop 分 支 
上 进行 开发 ， 或 许 会 有 一 个 人 被 指 

派 hotfix/bugs_in_membership 分 支 进行 修复 任 
务 ， 诸 如 此 类 的 ， 等 分 支 完成 开发 后 ， 再 将 释 更 推 
送 到 踪 端 储存 库 和 里。 


眼 尖 的 你 可 能 会 发 现 ， 这 个 vser2 的 本 地 分 

有 master 而 已 ， 跟 我 们 原本 建立 的 那个 工作 目 色 
有 些 不 一 样 。 之 前 在 【第 25 天 : 使 用 GitHub 踪 端 
储存 库 - 观念 篇 】 文 章 中 不 是 提 到 说 " 把 这 些 “ 本 
地 扎 跳 分 支 : 锡 篇 是 一 种 1! 唯 读 J 的 分 广 : 吗 ? 汽 

本 地 分 支 要 怎样 进行 呢 ? 


关於 这 一 点 ， 各 位 也 不 用 担心 ，Git 早 就 帮 我 们 想 好 
了 。 假 设 你 现在 被 赋予 的 任务 是 去 开 

发 hotfix/pbudgds_ in membership 分 支 ， 普 负 责 把 
变更 错误 修正 ， 你 可 以 直接 执 

行 git checkout hotfix/bugs_in _ membership 将 


这 个 本 地 追 跳 分 支 : 给 取出 (checkout)。 


C:N\sandqbox-multi-branch-user2>dgit branch 一 
IE 
remotes/oridgin/VHEAD -> origin/masteL 
remotes/oridin/dqeveLoPp 
remotes/oridin/feature/aspnet_ idqentity 
remotes/oridgdin/yhotftix/buds_ in membership 


Femotes/oridin/masteL 


C:N\sandbox-multi-branch-user2>dgit checkout hotfi 
Branch hotfix/budgs_ in _ membership set up to 七 ack 


meeshaie 汪 全 om 和 CsEoamnE 


Switched to a new branch "hotfix/pbugds_ in members: 


C:N\sandbox-multi-branch-user2>dit branch 一 
x hotfix/buds_ in membership 
maseem 
remotes/oridgin/VHEAD -> origqin/masteL 
remotes/oridin/dqeveLoPp 
remotes/oridin/feature/aspnet_ idqentity 
remotes/oridgin/hotftix/budgs_ in membership 


Femotes/oridin/masteL 


人 hotfix/pbugs_in_ membership 这 个 “本 地 

追 跳 分 支 : 后 ，Git 会 动 攻 你 建立 起 一 个 同名 的 "本 
地 人 分支: ， 所 以 你 根本 不 用 担心 有 没有 本 地 分 支 的 
青 形 。 


:sandbox-multi-hbranch-user2>g9it branch 一 a 


-> oFigin/master 


:N\sandbox-multi-hbranch-user2>g9it checkout hotfix“hbhugs_in_membership 
Branch hotfix-hbhugs_in_memhbership set up to thack Femote branch hotfixhbud 
bership from origin - 


Switched to a new hbranch "hotfix“hbugs_in_memhbership' 


:Nsandhbox-multi-hbranch-user2>9it branch 一 aa 


master 
-> oFigin/ymaster 


:\sandhbox-multi-hbranch-user2> 


这 时 我 们 模 据 在 hotfix/bugs_in_ membership 这 


个 :本 地 分 支 : 建立 一 个 版 本 : 


CNsando5cox=multi=branch=user2>git status 
# On branch hotftix/budgs_ in membership 
生 总 眉目 十 有 可 二 攻 训 OninidL 让 是 区 让 站 十 三 本 二 全 二 全 忆 总 7 CEEa 


C:N\sandbox-multi-branch-user2>echo Sdqate 邓 革 七 Ime 委 


CNsandbox=multi=-branch=-usez2>g9it add 


C:N\sandbox-multi-branch-user2>d9it commit -im "Add 
[hotfix/pbugs_ in membershipPp 250e907] Adqdq a.txt 
EeeschanogsQARSSTETOIGS 


Create moaqe 100644 aa .二 Xt 


目前 的 版 本 线 图 如 下 : 


sandbox-multi- branch 四 sandbox-multi-branch-user2 X 


4 File Status All Branches .v ， 回 Show Remete Branchss Date Order 
人 Working copy Graph 
4 Branches 他 hotipybugs_ in_membership EPE 
4 五 not EBDEEIEERITEEG[EEi 


肝 master 人 
4 Tags 
入 1.00-betal 
4 Remotes 
4 旺 origin 
本 develep 
登 HEAD 
4 胶 feature 
一 aspnet identity 
4 号 hotfix 
过 bugs in_membership 
过 master 


接著 如 果 你 想 将 变更 推送 到 踪 端 ， 只 要 下 
寻 9it Push origin hotftix/pbudgs_ in membership 


即 可 将 变更 推送 回去 : 


C:\sandbox=-multi-branch-user2>dit Push origin ho 

Countind objects: 4，dqone. 

Deltaiconmneressicn usinog up Lo Enhnreeaas 

Compressind objects: 100g (2/2)，dqone . 

NETEIIOECD 可 SEE 二 005 大 (大 ) 丰 2904OYEES 0 bytes 

Total 3 (aqelta 0)，reusedq 0 (qelta 0) 

下 S 硬 gg EnnoEecmeaegaegeoyes088yEanmalee 关 mmsEbranchn 
6eeee88..250e907 hotfix/pbugs_in membership 一 


不 过 目前 为 止 ， 你 所 推送 回去 的 ， 只 
有 hotfix/pbudgs_in _membership 这 个 分 支 的 版 本 


而 已 ， 你 站 没 有 将 变更 “ 合 儒 ,， 回 master 分 支 。 

这 样 操 作 所 代表 的 意思 是 你 将 变更 放 上 踪 端 储存 
库 ， 目 的 是 为 了 将 变更 可 以 让 其 他 人 看 到 ， 也 可 以 
取 回 继续 修改 ， 有 【第 26 天 : 多 人 在 同一 
个 和 未 端 储存 库 中 进行 版 控 】 文 章 中 讲 的 版 控 流 程 一 


冰 o 


如 果 你 想 合 供 回去 ， 可 以 先 切换 至 waster 分 支 ， 
再 去 合 任 hotfix/bugs_in_ membership 分 支 的 释 


更 ， 最 后 在 推送 到 踪 端 储存 庆 。 如 下 指令 范例 : 


C:N\sandbox-multi-branch-user2>dgit branch 一 a 


*x hotfix/pbugds_ in _ membership 
IaSiEe 
zemotes/oridin/HERAD -> oridin/masteL 
remotes/oridin/dqeveLoPp 
remotes/oridin/feature/aspnet_ idqentity 
remotes/oridgin/hotftix/buds_ in membership 


zemotes/oridin/masteL 


C:N\sandqbox-multi-branch-user2>dit checkout|maste 


Switchedq to pranch 'masteLc ' 


C:NXsandbox-multi-branch-user2>dit merde hotftix/Pb 


Updating 6eeee88..250e907 


East-Eorwarda 
局 二 | 用 
1 file changdedq，1 insertion (+) 


Create moaqae 100644 .二 Xt 


C:N\sandbox-multi-branch-user2>d9it Push 
Total 0 (aqelta 0)，reusedq 0 (aqelta 0) 
To g9itaegithub.com:doggvy8088/sanadbox=-multi-pranch 


6eeee88. .250e907 master -> masteL 


:Nsandbox-multi-hbranch-user2>git branch 一 aa 


maste 
-> oOFigin/maste 


:Nsandbox-multi-hbranch-user2>9it checkout mastek 
Switched to branch “mastek” 


:Nsandbox-multi-hbranch-user2>9it meFkgqe hotfixhbhugs_in_memhbership 
pdating 6eeee88 . .259e987 
Fast-foFward 

a-txt 上 工 

1 file changed。 1 inseFtionCG+> 

cheate mode 199644 a-txt 


:\sandbox-multi-hbranch-user2>git push 

otal 9 《delta 89>。Feused 89 《delta 0) 

0 9itoegithuhb .com:doggqy8988/sandhbox-multi-hbranch .gtit 
6eeee88 . .25Be997 masteF 一 >》 mastek 


:\sandbox-multi-branch-user2>。 


如 此 一 来 ,master 的 分 支 内 容 就 成 功 被 更 新 ， 冰 且 
推送 到 这 端 储存 库 了 


寻 
曾 
昌 


然 泵 ， 其 他 的 分 支 也 都 是 用 类 似 的 方式 有 运作 


今 今日 小 颖 


今天 更 进一步 介绍 了 Git 更 接近 实务 面 的 版 控 流 
程 ， 让 大 家 透 过 不 同 的 分 支 进行 开发 ， 彼 此 之 问 做 
一 个 有 效 区 隔 ， 然 后 还 能 在 同一 个 让 端 储存 库 中 进 
行 版 控 ， 同 时 享受 了 集中 式 版 本 控 管 的 特性 ， 以 及 
分 散 式 版 本 控 管 的 弹性 ， 非 常 优秀 不 是 吗 ! ^ ^ 


我 重新 整理 一 下 本 日 学 到 的 Git 指令 与 参数 : 


。git push --all --tags 


git fetch --all --tags 


git branch -a 
。 git checkout hotfix/bugs_in_membership 


git push origin hotfix/bugs_in_membership 


。 HOME 

。 回 目 色 

。 前 一 天 : 多 人 在 同一 个 带 端 储存 库 中 进行 版 控 

。 下 一 天 : 了 解 GitHub 上 forks 与 pull request 
的 版 控 流 程 


第 28 天 :了解 GitHub 的 
fork 生 pull request 版 控 流 


程 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/28.md 


我 们 知道 Git 储存 库 将 没有 什么 上 权限 控 管 ， 的 概 
念 ， 因 为 他 是 分 散 式 的 版 本 控 管 系统 ， 沼 你 执 

行 git clone 之 后 就 会 把 整 份 所 有 完整 版 本 帮 史 的 
储存 库 下 载 回 来 ， 接 著 你 就 可 以 在 本 地 离线 的 进行 
开发 与 建立 版 本 ， 最 和 后 再 将 释 更 推送 到 乏 端 储存 
库 。 不 过 ， 如 果 我 们 只 有 一 份 趟 端 储存 库 的 话 ， 这 
代表 大 家 都 有 权限 将 变更 推送 到 踪 端 储存 库 。 
此 ，GitHub 揉 用 了 forks 与 pull request 的 流程 ， 
让 你 可 以 做 到 基本 的 权限 控 管 。 


设 定 GitHub 专案 的 权限 控 管 - 个 人 幅 
号 


在 GitHub 的 个 人 帐户 下 ， 兹 没有 甚 诬 权 限 控 管 的 
机 制 ， 所 以 只 要 你 授权 特定 人 为 协同 开发 人 员 
(Collaborators)， 他 就 能 自由 的 Push 与 Pull 专案 
原始 码 。 


我 以 我 之 前 在 GitHub 上 建立 的 某 个 专案 为 例 ， 专 


一 -一 
案 和 


周 址 : https:/github.com/doggy8088/ 


DataDictionaryCreator 


GO) 】 This repository ~ Search orbypeacommand 加 ”Explore 


E 」 doggy8088 / DataDictionaryCreator 


This project is clone from http-Wdatadictionary.codeplex.cormy 一 Edit 


4commits 1 branch 0 releas' 


P branch master ~v ”DataDictionaryCreator /日 


Update DataDictionaryCreator.csproj S 
咖 wh authored 16 days ago 


本 DataDictionaryCreator Update DataDictionaryCreator.csproj 


入 该 网 址 后 ， 昌 选 右 侧 吐 单 的 Settings 堪 结 进 


少 Pulse 


Prol 16 days ago 

myVisual Studio 2012 16 days ago E Graphs 
der into tracked version 16 days ago PP Network 
nyVisual Studio 2012 16 days ago 


SSH clone URL 
Gicegichub.ccm:doc 良 


You can clone with HTTPS 
SSH, or Subversion @@ 


然后 就 可 以 加 入 授权 的 协同 开发 人 员 ， 这 壬 要 输入 
的 是 对 方 在 GitHub 上 的 帐号 : 


GO 国 This repository ~ St riypt Immand 昌 Explore  Gis 


doggy8088 / DataDictionaryCreator 


Options Manage Collaborators 
Collaborators 4 一 
家 诈 | 
Service Hooks 本 人 
盟 will Will Leinweber 
Deploy Keys JW willettsd 
:willawn 


willashley Will Ashley 


设 定 成 功 的 图 示 如 下 : 


GO 四 This repository * 全 Explore 《 


doggy8088 / DataDictionaryCreator 


ODptions Manage Collaborators 
Collaborators 辆 5 {remove) 
Service Hooks 

Deploy K 


但 由 於 你 没 办 法 设 定 更 细 的 Git 各 端 储存 库 权限 ， 
所 以 只 要 被 指派 的 人 ， 就 能 角 存 取 完整 的 Git 束 端 
储存 库 ， 大 家 都 能 对 任意 分 支 进行 推送 (Push)、 拉 
取 (Pull) 或 删除 分 支 等 动作 ， 要 是 围 队 遇 上 天 兵 ， 


那 可 能 会 是 场 炎 闪 。 


设 正 GitHub 专 闪 的 权限 控 委 - 组 织 帐 
纺 
在 GitHub 的 组 织 帐户 下 ， 就 可 以 设 定 人 员 群 组 


(Teams)， 你 就 可 以 在 群 组 上 设 定 更 细 的 权限 ， 其 
中 包括 三 种 权限 : 


。Pull Only ( 唯 读 ) 
。Push & Pull (可 读 可 写 ) 
。 Push, Pull & Administrative (可 读 可 写 以 及 专 


案 管 理 权 限 ) 


This team grants the following permissions 


Pull Only 加 Save Team 


Pull Onl 从 
Push & Pull 
Push,. Pull & Administrative 


Repositories 


设 定 群 组 的 方法 如 下 : 
Gist Blog Help 墨 doggys08g 晤 当 队 


人 Unwatch ~ 11 食 Star 0 人 Fork 13 


《> Code 
eS 10 contributors 
人 lssues 348 


人 Pull Requests 0 


国 Wiki 
latest commit bl1452d6zas 雇 
24 days ag0 4 Pulse 
13 days ago 
全 Graphs 
2 hours ago 
了 Network 
3 hours ago 
21 days ago 光 Settings 加 
a month ago 


SSH clone URL 


gicegichub .Com:mir 


网) 


You can clone with HTTPS， 
SSH, or Subversion .外 


团 Clone in Desktop 


cp Download ZIP 


然后 选择 围 队 : 


人 加 This repository ~ f 名 ”Explore 


PRIVATE 二 miniasp / 本 汪 二 汪汪 


Options Teams 


Collaborators miniaspiowners 


Semice Hooks 他 miniasp1 册 Mteam 加 


Deploy Keys 的 miniaspji-teamadmin 辐 
Add 


Usageforthis repository is billedto miniasp 


你 也 可 以 点 选 刘 入 组 织 设 定 页 面 ， 进 一 步 的 来 挑 导 
围 队 成 员 : 


蝇 ， 生 This repository ~ Search orypeacommand 


PRIVATE 


Options Teams 


Collaborators 


的 miniaspiowners 


人 惠  seamortpeacmmans 加 Explore Gist Blog Help 辕 doooyaoss 日 义 必 


目 Repositories 。” 合 Members 本 人 
本 Find arepository Search AI Publc Private Sources Forks Mirors 


国 国 天 得 Javascript 俯 0 了 13 


Lastupdateg3hours ago 


多 奇数 位 创意 有 限 自 Jayascript 俱 0 1 


公司 入 


Lastupdated s days ago 


miniasp 

9 Taipei Taiwan 自 这 三 0_ po0 
http:ywww miniasp comy : 下 生生 到 
Joined on May 19, 2013 Lastupdated 13 days ago 


0 4 25 


pualicrepos prwalerepos members 食 0 2 
() 专 Search oriype acommand 仿 Explore Gist Blog Help 
置 doggy8088 Manage teams on namieajv 本 
二 miniasp Removingauserfrom this listwill remove them from 
fepositories. 
Organization Profile 
Billing Members of miniasp 
Payment History 
Security History 
Applications 
Owners 天 
mbers 
PRIVATE REPOS 40F10 尝 


[ 洗 量 : 加 “ Explore Gist Blog Helip 


miniasp 


News Feed Pull Requests lssues 


7 


tp 2repositories Remove 
Remove 
Remove 
如 16 repositories Remove 
tp 1repositor Remove 


Remove 
New Team 
miniasp 


lssues Teams 


Name This team grants the following permissions 


Pull Only 站 Save Team 


Members Repositories 


使 用 Fork 功能 


英文 的 Fork 字面 翻译 是 又 子 , 的 意思 ， 就 好 像 你 
刀 叉 去 把 食物 又, 起 来 一 样 ， 直接 把 菜 挪 放 到 你 
自己 的 愉 子 壬 ， 我 比喻 的 菜 4 就 是 你 要 复 抽 的 


GitHub 专案 ， 而 盘子， 就 是 你 的 GitHub 帐号 。 


主 : 老外 用 刀 叉 比较 多 ， 如 果 GitHub 是 台湾 发 展 
的 ， 这 个 单字 可 能 会 是 Chopsticks (筷子 )， 哈 ! 
XD 


现在 我 们 以 https:/github.com/doggy8088/ 
DataDictionaryCreator 为 例 ， 这 个 专案 ， 你 当然 沿 


有 写 入 , 权限 ,只 有 唯 读 , 而 已 。 


我 现在 登入 另外 一 个 GitHub 帐号 人 LearnGitEorKS 
)， 然 后 将 该 专案 " 又 4 到 这 个 帐户 自己 GitHub 帐 
号 下 : 


口 四 This repository =。 Search orbpea a 加 Explore Gist Blog Help LeamGitForks 避 尺 对 
doggy8088 / DataDictionaryCreator 地 watch ~ 2 全 Star 0| EEork 0 
This proiectis clone from http-jdatadictionary codeplex.corny/ 
《> Code | 
4 comrmnits 1 branch 0release 1contribut 
Q@ lssues 
PP branch master ~ DataDictionaryCreator /日 m PullR 
Update DataDictionaryC 国 Wiki 
别 wu aunored 
翻 DataDictionaryCreator 个 Pulse 


目 .giignore 


按 下 去 之 后 ， 他 骨 子 壬 其 实 就 是 使 用 sit clone 来 
复 秽 该 专案 到 你 的 GitHub 帐号 下 ， 估 计 只 要 十 几 
秒 钾 就 会 复 秽 完成， 看 你 复 抽 的 专案 大 小 : 


GO e This repository ~ ” Search ortype 3 Comma 回 “” Explore ! 


LearmgGitForks / DataDictionaryCreator 


forkedfrom doggy8088/DataDictionaryCreator 


Forking doggy8088/DataDictionaryCreator 


Were forking a repository just for you. 上 should only take a few seconds. Refresh at will 


完成 后 ， 在 你 自己 的 帐号 下 ， 就 会 有 个 完全 一 样 的 
Git 专案 被 建立 ， 但 会 在 名 称 下 显示 一 

段 forkea fronm 提示 你 该 专案 是 来 从 哪 壬 复 抽 过 来 
的 。 


加 人 This repository ~ ”Sesarci or ype 3 COmma3n6 加 “Explore 


LeamGitForks / DataDictionaryCreator 


forkedfrom doggy8088/DataDictionaryCreator N 


This project is clone from http:/datadictionary.codeplex.cormy 一 Edit 
4 commits 1 branch 0 release': 


P pbranch master ~ ， DataDictionaryCreator / 卓 


This branch is 0 commits ahead and 0 commits behind master 


Update DataDictionaryCreator-csproj 
嗓 Will authored 16 days 390 


柄 DataDictionaryCreator Update DataDictionaryCreator.csproj 


因为 该 专案 已 经 在 你 自己 的 帐号 下 ， 所 以 此 时 你 已 
人 -自己 的 这 端 储存 库 , 在 用 ， 
全 没有 读 写 权限 的 问题 。 


因为 Git 是 个 分 散 式 版 本 控 管 系统 ， 只 要 你 有 fetch 
的 权限 ， 基 本 上 就 可 以 抓 到 该 版 本 库 的 完整 版 本 释 
更 历程 。 


使 用 Fork 过 的 Git 过 疡 储存 库 


在 版 本 控 管 方面 ， 使 用 上 关乎 跟 用 自己 的 Git 束 端 
储存 库 没 什么 两 榜 ， 而 且 你 也 有 完整 的 历史 纪 人 。 
请 记得 这 份 资料 是 从 https:/github.comy/ 
doggy8088/DataDictionaryCreator 复 抽 过 来 的 就 
0 


我 们 先 取得 这 端 储存 库 回 来 : 


C:N\>dit clone ditaegithub.com:LearnGitEorks/DataD 
RSNEoiej 关 人 芭蕉 NEENDNEenEaRoioENENAGIS SENEGNS 

remote: Countindg objects: 57，dqone . 

remote: Compressind objects: 100g (45/45)， adqone . 
RSECETToEDTJECESR /放生 页 ( 作 下 务 田 下 23600RFOEB 42 . 
Receiving objects: 100s (57/57)，94.08 KiB| | 42. 
RSSGORN 可 < 开 荆 00 呈 (全 世 /各 思 ) 克 是 OnmS 


C:N\>cdq DataDictionaryCreator 


人 DaEammeteionafeyeeEesESF 


然后 我 们 建立 起 一 个 版 本 ， 然 后 把 变更 推送 回去 : 


C:N\DataDictionaryCreator>echo TEST > test .md 
C:N\DataDictionaryCreator>dit adqd 


C:NXDataDictionaryCreator>dit commit -mm "Addq a te 
[master b2004b0] Add a test.mdq for test Purpose 
二 amdoeaoA ESSEEESRONRRG 


create moaqe 100644 test .ma 


CGINDatEammetkneonaieyeeeaEEooi 电 Si 

全 全 疝 站 上 二 人 可 SS 

Delta _ compression using up to 8 threads . 
CoimoressnngEobgEcesR 0 ( 必 败 2) 下 本 aOimSE 

WHEN ES EU (已 汶 3 285E YES 到 | 攻 U| bytes: 
Total 3 (qdqelta 1)，reusedq 0 (qelta 0) 

To gitQedithub .com:LearnGitEorks/DataDictionaryCL 


c29aaab. .pb2004b0 master -> masteL 


GDaEamTetmonaiyeGEEaESTE 过 


使 用 pull request 将 变更 合 儒 回 党 初 的 
GitHub 专案 


刚 | 辣 | 我 们 用 DearnGitForks 身分 ， 把 专案 

从 aogsgy8088 这 亡 Fork 回来 ， 然 后 

用 LearnGitEorks 的 身分 git clone 回 本 地 端 ， 
建立 版 本 和 后 再 用 sit push 推 回 GitHub 


的 LearnGitEorkSs 下 。 


现在 我 们 要 把 储存 在 LearnGitForks 帐号 下 


的 DataDictionaryCcreator 专案 [ 合 儒 ， 


回 dogqgv8088 帐号 下 的 DataDictionaryCreatoLr 


专案 ， 这 时 因 和 为 是 跨 帐 号 的 ， 所 以 必须 利 
用 Pul1l reduest 才能 把 释 合 供 ， 回去 。 


广 : 这 里 的 pull redquest 照 字面 翻译 是 上 拉 取 要 

求 ， 的 意思 / 代表 要 以 LearnGitForks 的 身分 7 
请 aoggy8088 把 我 的 继 更 给 拉 回 去 (sit pul1)， 但 
你 不 能 强迫 对 方 拉 (pul1) ,所 以 必须 拜 话 (zequest) 
对 方 拉 ， 所 以 才 叫 做 pull request。 


这 时 你 要 用 LearnGitEorks 的 身分 7 过 


到 httpbps://dgithub .com/dqoggy8088/DataDictionaryCrea 


AN 


这 一 页 ， 然 后 点 建 Pull Requests 页 繁 : 


上 


doggy8088 / DataDictionaryCreator 地 Watch ~ 2 让 Star 0 是 Fork 1 


This prolectis clone from http-jdatadictionary.codeplex.corny/ 


4commis 1 branch 0 releases 1contrib 


P pranch master " ”DataDictionaryCreator /四 人 Pul Requests 


Update DataDictionaryCreator csproj 鲁 Wi 


然后 点 跑 New pull reauest 按钮 ， 淮 人 备 建 立 一 个 
新 的 pull request 项 目 : 


)re Gist Blog Help 必 LearnGitForks 医 兴 驻 


地 Watch 2 食 Star 0 对 Fork 1 


New pull request 呈 
《7 


四 


n| 


接 下 来 你 要 遗 择 两 个 版 本 (两 个 commit 物件 ) ， 
GitHub 才能 建立 patch 档案 ， 也 才能 知道 要 合 供 那 
些 东 西 回 去 。 但 你 遗 不 到 自己 fork 过 的 版 本 ， 央 此 
你 要 点 屠 compare across forks 


吾 ， 下 This repository rch Explore  Gist Bl 


doggy8088 / DataDictionaryCreator 


记 


base: master 20mpare: master 


Chooseabase branch 
“本 卫 
国 相 一 二 = 一 = 


然后 你 就 可 以 选择 到 自己 fork 过 的 专案 与 分 支 了 ! 
不 过 ， 过 一 步 要 特别 注意 不 要 遗 错 ， 你 的 版 本 因为 
比较 新 ， 所 以 应 该 要 把 右 逮 的 版 本 跑 择 成 你 的 ， 
GitHub 才 知 道 


从 dogqgv8088/DataDictionarycreator 的 masteL 


分 支 ， 到 LearnGitEorks/DataDictionaryCreator 


的 master 分 支 ， 到 底 发 生 了 那些 版 本 变化 。 


也 :se fork doggy8088/DataDictionary..， ~ aa- master ~ TO dogqy80881DataDicionay pare -master " 四 


Choosea Head Repository 


There isn't anythin | | | 


Youl needto use two different branch | w doggy8088/DataDictionarCreator 
Check out some of these 3 


w LeamGitforksiDataDictionaryCreator 


器 master@({1day}..master 


最 后 你 会 看 到 有 哪些 档案 以 及 哪些 地 方 变 更 了 ， 然 
后 你 就 可 以 按 下 Click to create a pull request for 
this comparison 建立 起 一 个 pull request : 


GO This repository * 加 Explore 


doggy8088 / DataDictionaryCreator 


人 GoGSGY8088 :masceZ LearnEGicEozks:1ma3LeZ 
Click to create a pull request ”> comparison 
1 1 


Oct 28, 2013 


哑 Wi BaGG a eat.mG for teat purpose 


Showinc 1 changed file with 1addition and 0 deletions 


了 凡 test.md 


No commit comments for 


最 人 后， 我 们 先 看 一 下 右上 角 有 个 Able to merge 的 
地 方 ， 会 预先 告诉 你 合 供 的 结果 ， 显 示 你 的 版 本 跟 
目前 的 soggv8o8s:master 的 版 本 是 否 有 衢 突 发 
生 。 如 果 都 没 问 题 ， 再 输入 一 些 说 明文 字 给 原作 者 
人 doggy8088 ) 有 普 按 下 Sendq PulL1lL redquest 即 吕 
建立 完成 。 


doggy8088 / DataDictionaryCreator 


也 


Add atest md fortest purpose 


Write Preview 


地 Watch ~ 2 食 Star 0 HEF 


This is atest pull requestj| 


selecting them， 


Edit 
Comments are parsed with GitHub Flavored Markdown w Able to merge 
These branches can be 
互 automatically merged 


Send pull request 


圈 octz8,z013 


枝 wu ad a teat.md sor eat purpose 
Showing fchanged file with 1addition and 0 deletions 


1 加 teat.na 


b2004b0 


Show Diff Stats 


Open View file @ b2ee4pe 


广 Github for Mac;Github for Windows 已 增加 pull 


request 功 能 


， 钱 Publish | 盖 


Pull request 


from such-future into master 了 


Title 


Description.… 


妆 This pull request can be automatically merged. 


Your local commits will be synced to GitHub. 


接受 pull request 的 要 求 ， 确 认 合 供 回 
自己 的 GitHub 专案 


最 后 一 个 步骤 ， 则 是 让 原作 者 ( aoggy8088s ) 去 看 
有 谁 传送 了 一 个 pull request 给 自己 。 


现在 我 重新 以 aoggy8088 登入 GitHub ， 范 到 该 专 
案 发 现 有 一 个 Pull Requests 进来 了 : 


re Gist Blog Help 辕 doggysosg 上 台 妆 了 


培 Unwatch ~ 2 仿 Star 0 中 Fork 1 


《> Code | 
1 contributor 
人 @ Issues 1 
人 0 Pull Requests 1 
必 
AL 
国 Wiki 
nit C29aaab5e5 家 
SS 分 Pulse 


doggy8088 / DataDictionaryCreator 


Al Requests 1 Open | Closed Sort Newest ~ 


Yours 了 Add atest.md fortest purpose 
This is atest pull request 


byLearnGitForks 3 minutes 396 mastez 


LearnGitForks 1 Keyboard shaortcuts available 到 


最 后 按 下 Merge pull request 即 可 完成 合 人 工 作 。 


doggy8088 / DataDictionaryCreator 售 Unwatch v 2 才 


LearnGitForks wants to merge 1 commit into dcggyaa8azmaster from LearnGiLFozka:maate: 
峙 Discussion CCcommits 末 国 Files Changed 于 
as 宇 本 
oa LearmGitforks openedthis pullrequest3 minutes ago Edit 
Add atest.md for test purpose 
No one is assigned ~ No milestone 变 ~ 


This is atest pull request 


ucan add more commits to this pull request by pushingto the master branch on LearnGitforksiDataDictionaryCreator 


You c: 

人 This pull request can be automatically merged- 
四 You can also merge branches on the command line | 下 Nerge Punrequest 
3 


今日 小 给 


做 到 这 里 ， 你 应 该 大 致 能 够 了 解 为 什么 会 有 fork 和 与 
pull request 的 存在 ， 最 主要 的 就 是 权限， 以 及 
版 本 库 隔 离 , 的 需求 。 一 个 上 千 人 的 专案 
(Linux Kernel)， 如 果 所 有 人 都 能 存 取 主 要 的 下端 
储存 库 ， 那 不 是 很 恐怖 吗 ! 


不 过 在 一 般 企业 壬 ， 你 不 一 定 要 这 样 做 ， 竟 操作 
的 步 又 确实 繁 开 了 些 。 均 际 要 和 皇 用 ， 就 要 靠 你 自 


己 判断 了 。 


参考 连结 


Fork A Repo 
Using Pull Requests 


Git workflow: Forks, remotes, and pull 
requests 


Fork a Repo, Compare Code, and Create a 
Pull Request 
Forks and Pull Redquests in GitHub 


。 HOME 

。 回 目 销 

。 前 一 天 : 透 过 分 支 在 同一 个 踪 端 储存 库 中 进行 
版 控 

。 下 一 天 : 如 何 将 Subversion 专案 汇 入 到 Git 储 
存 库 


第 29 天 : 如 何 将 
Subversion 专案 汇 入 到 Git 
储存 麻 


原文 : https:W/github.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/29.md 


当 你 越 来 越 了 解 Git 版 本 控 管 ， 一 定 会 越 来 越 想 把 
手 刀 的 Subversion ( 简称 SVN ) 专案 改 用 Git 进行 
版 本 控 管 。 但 研 於 两 者 的 版 本 架构 差别 甚大 ， 转 换 
的 过 程 稍微 麻烦 些 ， 主 要 是 要 打 些 指令 才 行 ， 还 好 
Git 已 经 内 建 了 许多 SVN 的 整合 指令 ， 让 我 们 可 以 
容易 地 将 SVN 专案 转换 过 去 。 本 篇 文章 将 介绍 如 
何 用 简单 的 四 步 又 ， 将 现 有 的 SVN 专案 转 成 Git 储 
存 库 ， 亚 将 转换 人 后 的 本 地 储存 库 送 上 下 端 储存 库 。 


准 全 使 用 者 清单 对 风 榴 


我 们 先 来 看 一 个 用 TortoiseSVN 的 Show log 看 到 
的 版 本 历史 清单 ， 在 Author 栏 位 看 到 的 只 有 上 使 


用 者 名 称 , 而 已 : 


丸 DAN\Projects\DoggyLibrarySolution - Log Mes' 
及 Filter by Messages, Paths, Authors, Revisions, BugJDs, Date, Date Range 
Revision Actions 。 Author Date Message 
下 .人 omsen. 2003 年 9 月 芋 肯 上午 0:1103、 楷 改 TextBoxcaiendac- 竹 入 名 六 | 
15 如 thomsen ”2005 年 7 月 14 日 下 午 08:47:50 s 正 DynamicIimageProcessor: 1.Path, 
14 。 曙  WilHuang 2005 年 7 月 14 日 下 午 07:58:22 ”新 增 保 哥 修 改过 的 DynamicImageProc 
13 明 thomsen 2009 年 7 月 2 日 下 午 02:46:02 修改 TextBoxCalendar: 新 增 1 介 Boolea 
12 全 doggy 2008 年 3 月 0 日 下午 01:04:30 修正 DetectEncoding,aspx,cs 中 对 档 神 
11 明 doggy 2008 年 3 月 8 日 下 午 07:07:46 修正 TextBoxCalendar 控制 项 在 Bndir 
2 引 
修改 TextBoxCalendar: 


坦 入 错误 日 期 格式 鲁 发 生 Exception 的 Bug 


不 过 ， 使 用 Git 必须 至 少 有 使 用 者 名 称 4 与 " 曙 
子 邮 件 地 址 ， 才能 建立 版 本 ， 所 以 我 们 必须 先 把 

SVN 专案 中 所 有 的 Author 取出 ， 站 设 定好 一 个 对 
应 档 ， 才 能 完整 的 将 SVN 专案 汇 入 到 Git 专案 中 。 


我 们 假设 2 个 变数 : 


。SVN 专案 网 

址 : https://svnrepo:23443/svn/DogdgyLibrarySolrt 
。SVN 工作 目 

色 :D:NAXProjectsADodgyLiprarySolLution 


昌 GIT 安装 路 径 : C:NProdgram Eliles (X86) 和 NGit 


请 注意 : 执行 svn 命令 必须 事先 安装 Subversion 
指令 列 工具 ， 下 载 建 绪 : Subversion Edge 
Download 


我 们 开 衣 “命令 提示 字 元 4 冰 进 入 SVN 工作 目 
销 ， 然 后 执行 以 下 指令 ， 你 会 得 到 一 


个 svNusers.txt 档案 : 


SET PATH=SsPATHS;C:NXProdram Eiles (X86)NGitANbinN 


svn 1og --quiet --xml | sedq -n -e "s/<NA/N?author: 


由 於 我 们 这 个 SVN 专案 只 有 4 位 开发 人 员 ， 所 以 


得 到 的 SVNUSseLrs .七 X 七 档案 内 容 如 下 ， 


世 

Pils Edt Visw Sesttings 了 

D 艳 矶 加 | el 和 色 | 的 二 | 国 : 
1 hoggy 

2  joe 

3 thomsen 

4 will1.Huang 

5 


接 下 来 ， 我 要 修改 这 个 档案 ， 在 每 一 行 和 后 面 加 上 = 
等 号 ， 再 加 上 “ 使 用 者 名 称 , 与 ' 电子 邮件 地 
址 ; ， 格 式 如 下 : 


SVnuser = GilitUsername <G1itEmail > 


修改 完 后 的 内 容 如 下 : 


名 
File Edit View Settings 2 
D 辟 四 加 | elyx 电 柜 | 的 和 | 国 RSlE 


1 doggy = will1 <wi11.huangeminiasp.com> 

2  joe = Joe Wu <joeaeminiasp.com> 

3 thomsen = Thomsen <thomseneminiasp.com> 

4 WwWwil11.Huang = will1 <wi11.huangaeminiasp.com> 
S 


将 SVN 专案 取出 站 瑟 换 成 Git 工作 目 


假设 我 想 将 GIT 工作 目 销 设 定 

在 G:\DoggyLibrarySsolution 痊 料 来 ， 那 订 你 可 
以 先 把 修改 后 的 svNusers .txt 档案 复 揭 到 c:\ 目 
色 下 ， 然 后 执行 以 下 指令 : 


dit sw clone https://svnrepo:23443/svn/DoggyLib 


如 果 你 可 以 存 取 的 SVN 储存 库 权 限 只 有 /trunk 而 
已 的 话 ， 你 不 能 使 用 --stdlayout 属性 ， 例 如 : 


djit sw clone https://svnrepo:23443/svn/DodggyLib 


这 个 指令 执行 时 ， 可 能 会 需要 你 输入 SVN 版 本 库 
的 登入 帐号 密码 。 


un clone https:《《 [sun/DoggyLihbrarySolution --no-metadata -h SUNUs 
ed empty Git repository in g:/DoggyLihbrarySolutionv-git 
ro ualidating seruer certificate for "https:// ， 
The certificate is not issued by a trusted authority。 Use the 
fingerprint to ualidqate the certificate manually 
ertificate information: 


2818 GMT until Jul 16 13:54:35 29298 GMT 


- Fingerprint: f6:75: :ce:e6:99:4c:ea:5f:52:63:98:7a: :77:68:a4 
ertificate problem- 
KR>eject。accept 《temporarily or accept 《permanent1y? p 
huthentication realm: 《 》Suhbuersion Repositor 
“WUill.Huang” 
tunkDo 
thPunk-Docs 
+empty_dir: trunk/Docs/ 
+empty_dir: trunk/Docs/ 音 
+empty_di unkzDocs/ 
: +empty_dir: trunkzHTML 
: +empty_dir: trunk/S9L 
: +empty_dir: trunkvWehbsite 


转换 和 后 的 结果 来 看 ， 你 会 发 现 转 换 人 后 的 Git 储存 

库 ， 版 本 资讯 非常 完整 ， 他 会 多 SVN 当初 留 

的 commit 时 间 和 与 作者 资讯 ， 过 里 的 作者 资讯 所 显 
示 的 使 用 者 名 称 与 电子 邮件 地 址 则 是 我 们 刚 硬 定 坟 
半 所 设 定 的 那些 对 应 资 计 


:N\>cd DoggyLihbrarySolution 


:\DoggyLihbrarySolution>git branch 一 a 


: *ySolution>dir 
区 8 磁 雁 是 TEMPORnRRY 
区 序 83D7?-4989 


G:\DoggyLihbrarySsolution 的 目 舒 


2P813719729 《DIR> 

PB137A1BA29 《DIR> 和 

PBl13A1L9729 最 《DIR> DogguyLihbrarySolution 
2P6137n1L97A29 旧 <《DIR> DynamicImageProcessSok 


Ca ySolution 2729 让 1og 
?duB3a72a8chb34 68hbhbelli” 
huthor: Thomsen 《thomseneminiasp-comy> 
Fri Sep 11L1 692:11:03 2089 +00090 


-二 - 


1 ] b 二 了 | 6dfht 
站 uthor: Thomsen 《thomseneminiasp-com> 
Date : Tue Jul 14 12:47:59 2989 +9999 


正 DynamicImageProcessor: 


1 .Path.Comhbine 的 Bug 《第 一 个 字 溃 为) SS 


|] 41Q 
huthor: Will 《 huangemin 
Tue Jul 14 11:58:22 20969 +0009 


旧 昌 村 DunamicImageProcessor 


HH 上 Expires Header 预 设 会 1 小 时 
芝 复 一 些 使 用 Suhstring 千林 E 出 现 的 Bug9 


在 此 : http:-/dunamicimagephocess -codeplex-com/ 


转换 SVN 的 忽 各 清 单 ( 即 svn:ignore 兢 
性 ) 
SVN 专案 中 有 所 谓 的 svn:iognore 属性 ， 这 等 同 於 


Git 的 .9itignore 忽略 清单 。 但 是 SVN 的 忽 略 清 
单 散 洛 在 每 个 目录 属性 中 ， 还 好 你 可 以 透 


过 9it Sn Show-Igqnore 指令 转换 这 些 资讯 为 Git 


的 格式 。 


接著 我 们 直接 透 过 以 下 指令 取得 .sitignore 忽略 
清单 档 的 内 容 : 


gsvnESshowsmognore 


不 过 你 可 能 会 遇 到 以 下 错误 : 


G:\DodgyLiprarySolLlution>dit svn show-Ignore 


confidg --get SsSvn-remote.svn.fetch :Frefs/remotes/ 


如 果 遇 到 这 个 错误 ， 代 表 sit svn show-ignore 找 
不 到 你 的 SVN 路 径 ， 这 通常 发 生 在 你 的 SVN 版 本 
库 使 用 了 标准 的 trunk, branches, tags 资料 结构 ， 
这 时 你 可 以 改 输 入 以 下 指令 : 


miEmSVn 本 SOwEgnemn 二 二 TU K 


:\DoggyLihbrarySolution>git Sun Show-ignoke 一 奔 tkunk 


ADoggyLihbrarySolution~ 
DoggvyLihbrarySolution 关 -suo 


ADoggyLihbrarySolution-DetectEncodingy~ 
DogguyLihbraryvSolutionDetectEncodinghbin 
DoggvyLihbraryvSolutionDetectEncodingohbjJ 


ADoggyLihbrarySolutionDoggvy-UI .WehbCcontFols/~ 
DoggvyLihbrarvSolutionDoggvy-UI .Webcontrolshbin 
DoggvyLihbraryvSolutionDoggy.-UI .Wehbcontrolsohbj 
DoggvyLihbraryvSolutionDoggy-UI .WehbCcontkFo1ls- 关 -usekr 


ADoggyLihbrarySolutionWehbsSite-Bin~ 
DoggvyLihbraryvSolutionWehbsite-BinDoggvy-UI .WehbcontFols .qdq11 
DoggvyLihbraryvSolutionWehbsite-BinDoggvy-UI .WehbcontFols .pdb 
DoggvyLihbrarvSolutionWehbsite-BinDetectEncoding-dl1 
DogguLihbraryvSolutionWehbsite-BinDetectEncoding-pdhb 


ADunamicImageProcessoF 
DynamicImageProcessok/ 关 -SUO 


ADunamicImageProcessokDunamicImagePhocessoF/ 
DunamicImageProcessok-DunamicImageProcessokhbin 
DunamicImageProcessokFk-DunamicImageProcessokohbj 
DunamicImageProcessokADunamicImageProcessoFkA 关 -USE 


ADunamicImageProcessokTesting~ 
DunamicImageProcessoFATesting- 关 -USek 
DunamicImageProcessokATestinghbin 
DunamicImageProcessokATestingohbj 


:\DoggyLihbrarySolution>。 


下 中 
条 


接著 我 们 建立 一 个 .sitignore 忽略 清单 
立 一 个 新 人 版本， 指令 如 下 : 


了 


gm 要 SSVnn 本 SOW 王 东 G 天 二 王 下 和 | 芷 册 和 基 汪 交 汪 本 ga 所 站 全 
9it addq .9itigqnore 


gneEccOmmamaueGseaeeOieEonmoe 二 全 GOImESNWVNE 


:\DoggyLihbrarySolution>git sun Show-ignoke -1 thunk > -9itignoFe 


:\DoggyLihbrarySolution>git add -9gitignoke 


:\DoggyLihbrarySolution>git status 
展 On branch master 
性 Changes to be committed: 
《use "qit Feset HEhD <file>---" to unstage) 


:\DoggyLihbrarySolution>git commit -m "Create -9qitignoFe from SUNY7 
[master 964459f ] Create -9itignoke from SUN 

1 file changed。31 inseFtions(C+7? 

cheate mode 1069644 .9itignoke 


:\DoggyLihbrarkrySolutiony> 


将 专案 推送 到 这 端 储存 库 


由 於 GitHub 在 预 设 的 情况 下 ， 只 能 建立 "开源 
三, 的 Git 专案 ， 所 以 我 们 这 次 改 用 Bitbucket 网 站 
来 建立 一 个 私有 的 Git 专案 (Private Repository)。 


三 名 Bitbucket Repositories ~ ， Create 全 


Create a new repository 


2 Name”| DoggyLibrarySolution 


Descripton || 


3 Access level This is a private repository 人 NA 


Forking | Alow only prvate forks Wi 0 


Repository type 
加 Mercurial 
Project management lssue tracking 
Wiki 
Language | Select an Option 黑 


4) [Cancel 


建立 完成 后 ， 按 下 Clone 去 复 投 Git 储存 库 网 址 : 


三 晶 Bitbucket Reposiones ” ceate @- 嫩 - 
Do LibrarySolution 
99y 以 了 由 Cone~ | Branch 上 由 Pulrequest … OO - 
合 息 wilh 枉 Share 
2 
Sie clone sicebicbuckec.org: dod 
Overview Source Commits Branches Pull requests Downk 如 


Need help 本 Visit Bitbucket 101- 


Clone in SourceTree 
E | sonemsourcemee | 
Add some code 

Ailassian SourceTree is afree Gift 


and Mercurial client for Windows 
You can starta brand new project or push 


Niake rhannes anr nilsh 


接著 就 跟 我 们 之 前 学 到 的 一 样 ， 把 现 有 的 专案 给 推 
送 上 去 ， 如 下 指令 


OremocES agoccnonnoneocnecueckeee oro mypccoun 


GE 本 BUS EmaisieeE 


:\DoggyLihbrarySolution?>git remote add origin gitehitbhucket-org: 《doggylihbrarysolution-git 


ion.git 《fetch? 
ion.git 《push》 


:\DoggyLibrarySolution>。 


今日 小 和 


就 这 样 简单 四 步 又 ， 就 可 以 把 SVN 专案 完整 的 转 
移 到 Git 储存 库 ， 是 不 是 非常 简单 呢 。 


事实 上 ， 这 个 工作 目录 还 可 以 持 We SR 
版 本 库 江 通 ， 可 以 commit 变更 ， 也 可 以 pull 变 
回来 ( 5it svn rebase )， 详 细 的 操作 说 明 只 要 吉 
行 。 help svn 就 可 以 取得 完整 说 明 。 沼 然 ， 我 

建议 转 过 去 就 转 过 去 了 ， 否 则 在 Git 环境 下 操 
和 SVN 总 几 得 怪 怪 的 ， 有 点 多 此 一 举 的 感觉 ， 但 
确实 有 可 能 有 这 种 需求 。 


*。 HOME 


。 回 目 针 


。 前 一 天 : 了 解 GitHub 上 forks 与 pull request 
的 版 控 流 程 
。 下 一 天 : 分 享 工 作 中 伙 个 好 用 的 Git 操作 技巧 


第 30 天 : 分 享 工作 中 继 个 好 
用 的 Git 操作 技巧 


原文 : https:Wgithub.com/doggy8088/Learn- 
Git-in-30-days/blob/masterwzh-tw/30.md 


终 於 来 到 了 最 和 后 一 天 ， 这 篇 文章 将 分 享 儿 个 好 用 的 
Git 操作 技巧 ， 或 许可 以 节省 你 不 少 Git 版 控 过 程 的 
时 间 。 


如 何 让 git pull/ push / fetch 不 用 输入 
帐号 、 密 三 


我 们 在 使 用 GitHub 的 时 候 ， 由 於 预 设 使 用 HTTPS 
通讯 协定 取得 Git 储存 库 ， 例 

如 : https://dgithub.com/dogqgy8088/frontendq-tools .di 
但 事实 上 你 可 以 改 用 SSH 选择 当成 取得 Git 下 端 储 
存 库 的 网 址 ， 如 下 图 示 : 


《> Code 


33 contributors 
1 Pull Requests 1 
状 Wiki 
Pull Request Compare 
办 Pulse 
1atest commnit dd6eft98dd1 良 bu Graphs 
af 
1 Network 
3 months ag0 
只 Settings 
You can clone with HTTPS 
作 SSH, br Subversion 外 
， 、 二 叶 《Clone in Deskto 
文 件 ， 这 些 工具 仅 针 革 一 般 桌 上 所 p 


cpP Download ZIP 


使 用 HTTPS 通讯 协定 来 存 取 GitHub 上 的 带 端 储存 
库 ， 由 於 无 法 记 居 帐 号 密码 ， 所 以 每 次 执行 下 端 储 
存 库 的 指令 一 定 都 会 被 要 求 输入 帐号 、 密 码 。 但 改 
用 SSH 的 话 ， 就 可 以 透 过 预先 定义 好 的 金 护 来 进 


行 身分 验证 。 


在 第 一 次 使 用 GitHub for Windows 工具 的 时 候 ， 如 
果 你 有 照 著 步 嫩 登入 与 设 定 ， 这 套 工 具 会 预 设 草 你 
产生 一 对 金 欠 ， 然 后 该 工具 会 自动 上 传 到 GitHub 


的 SSH Key 专区 ， 让 你 日 后 不 用 再 输入 帐号 密 
码 ， 就 能 顺利 的 操作 GitHub 上 的 下 端 储存 库 。 


这 一 对 金 欠 ， 预 设 就 放 在 suUsERPROFILEs\.ssh 资 
料 严 下， 如果 你 的 Windows 登入 使 用 者 名 称 

为 Will 的 话 ， 这 个 路 径 就 位 

於 c:\UsersN\will\.ssh 目 朱 下 。 这 针 金 欠 的 档 名 


分 别 是 g9iIthub_Frsa ( 私 欠 ) 熏 g9ithub_rsa.Pub ( 公 
) 


欠 ) ， 如 下 图 示 : 


和 司 站 隐 习 忆 二 | .ssh 

区 汪 = 用 。 共有 。 认 3 

| 口 关 药 下 了 区 定 i 轩 别 新 增 项 目 ~ 革 

| 过 aaa 六 号 攻 月 ES 了 到、 LA 轨 

| 移 至 ， 祝 乱 到。 开除， 重新 命名 新 涌 内 容 加 

国营 十 盾 径 辽 瓷 衬 交 7 局 
盘 耻 和 二 会 各 有 新 境 避 


全) 是 晶 CNUsersNWillN_ssh 


遇 -config A ”名 区 

在 志 

- at LJ github rsa 

机 [ 国 github rsa.pub 
-ss 


kn host SC- 
0 本 人 ubisher 广 人 年 


电 subversion 
出 Webstorm6 
Annnata 


修改 日 2013 有 04 


也 因为 这 一 对 金 欠 的 存在 ， 所 以 你 在 Git Shell 底 
下 操作 Git 指令 ， 所 有 针对 下 端 储存 库 上 的 操作 ， 
都 不 需要 再 次 输入 帐号 密码 。 


事实 上 ， 不 用 输入 密码 的 原因 是 /GitHub for 
Windows 工具 已 经 把 SSH 金 锡 上 传 到 GitHub 网 
站 了 ， 设 定 的 网 址 


在 https:/ /dithub.com/settindgds/ssnh ， 我 们 可 以 
从 以 下 图 示 看 出 设 定 的 位 址 : 


xx 
全 C 和 划 GitHubincIuslhttps/githubcom/setinoysh | 家 志 三 
GO =。 arch ortypea command 加 Explore Gist Blog Help 围 dooososs 脸 
辕 doggysoss Need help? Check out our guide to generating SSH keys or troubleshoot common SSH Problems 
Profile SSH Keys Add 
Account Settings Ti 
Emails Te 
Notification Center 1 
Billing GitHub for Windows - WILL8PC (8e-56-32: 2d:1a-d3) 
Payment History ee se tel 4 
SSH Keys np 各 鹤 -ip qoe 
Security History ep 3 rm 
Applications re 1 


不 过 ， 如 果 你 希望 在 ' 命令 提示 字 元 , (〈 非 
Windows Powershell 执行 环境 ) 下 也 可 以 不 用 输入 
帐号 密码 验证 ， 那 冻 你 可 以 党 试 

将 sUsERPROFILESN\.ssh 资料 来 下 的 两 个 档案 分 别 
把 sithub_rsa 复 抽 一 份 改名 成 ia_rsa， 然 后 

把 sithub_rsa.pub 复 揭 一 份 改 名 

成 ida_rsa.pub， 即 可 完成 设 定 ! 完成 后 如 下 图 


名 帮 修改 日 期 枯 型 大 小 
L github_rsa 2013/1/24 上 午 11:04 。” 竹 宗 2KB 
晓 github rsa.pub 2013/1/24 上 午 11:04 Microsoft Pubiisher 文 件 1KB 


2013/1/24 上 午 11204 


2013/71/24 上 午 11:04 Microso 从 Publisher 文件 
[] known_hosts 13/10/29 下 午 10:04 ”和 衬 2KB 


这 样 就 可 以 大 功 告 成 。 


不 过 ， 如 果 你 之 前 从 GitHub 复 揭 回来 的 版 本 库 是 
用 HTTPS 通讯 协定 的 话 ， 那 序 你 还 必须 将 这 个 踪 
端 URL 修改 成 ssh 的 格式 。 例 如 我 们 现 有 的 
remote URL 如 下 : 


G:N\dqemoAfrontendq-toolLls>dit remote 一 V 
GTOT 由 世 世 TS 信人 ENDbEeemyaegog8088 EeeonmEEnma=te 
GO 全 下 臣 启 S 区 人 O 臣 提 本 ECmyaeogoy80887EEOnEend=to 


我 们 可 以 

用 it remote set-url origin 9itegithub.com:dodqdgy8 
来 将 现 有 的 乏 端 URL 改 成 SSH 的 通讯 协定 ， 请 

一 下 执行 过 程 : 


G:N\qemoANftrontendq-tools>dit remote 一 V 
AN 
Gramonr EtS NoaEnao 本 eemasogodw8088E2onmEenad=-to 


G:\dqemoAxfrontend-tools>dit Push 
UsercnmamefESsIhEEDOSRoaEnUOsCom aaF Poula 
人 


G:\dqemoAxfrontend-toolLls>dit remote set-url oridin 


G:N\qemoANftrontendq-toolLls>dit remote 一 V 
GO Gate Ga 的 更 COTIE 人 ooeoy808S7Reonmeenmaqools 
Oraionrnaeoeaoguenuobosecmgacogoy8bS8EeonmeEengqrools .| 


G:\dqemoAxfrontend-tools>dit Push 
Everything up-to-dqate 


人 enmnaeNEreonEEDnaEE CULS 


如 此 一 来 ， 就 可 以 不 再 需要 验证 帐号 密码 了 。 


如 何 让 操作 Bitbucket 踪 端 储存 库 时 ， 
也 可 以 不 用 输入 帐号 、 密 码 
由 於 GitHub for Windows 才 有 我 们 建立 好 一 个 现成 的 


金 欠 ， 如 果 你 要 直接 沿用 ， 可 以 透 过 以 下 步 又 产生 
GitHub 与 Bitbucket 都 能 支援 的 SSH 金 欠 格 式 : 


SourceTree 的 话 ， 将 会 在 以 
各 径 找到 PuUttLyYyden .exXe 工具 ， 站 请 直接 并 
人 


路 


径 : C:NAXProdgdram Eiles (xX86)A\ALt1LassianANXSourceTre 


重 晓 ， 本 楼 盒 登 (CJ) ， program Files (x86) ， Aitlassian ， SourceTree ， tools ， putty 


和 名称 “ 修改 日 期 桥 型 大 小 
站 ucENCE 2013/9/2 上 午 11:42 ”入 案 2KB 
伪 pageantexe ”2013/10/24 下 午 03:08 ” 话 用 程式 143 KB 
嘿 plinkexe 2013/10/24 下 午 03:08 ” 产 上 司 388 KB 


n32 


既 ' puttygenexe 和 奏 用 程式 183 KB 


File Key Conversions Help 


Key 
No key-. 


Actions 
Generate a publicyprivate key pair 
Load an existing private keyfile 


Savethe generated key Save public key Save private key 


Parameters 


Type of keyto generate: 
CSSH-1(RS 和 图 SSH-2 RSA C 〇 SSH-2DSA 


Number of bits in a generated key- 1024 


. 接著 载 入 8sUSERPROFILESN. sshN\dithub _rsa 
私密 金 欠 档 案 ， 半 复 抽 产生 和 后 的 一 串 融 码 ， 这 
就 是 SSH 金 钴 中 的 公 欠 : 


从 在 到 去 的 短 取 苦 序 人) 
里 示 Unicode 注 逢 字 元 多 
后 入 Unicode 尘 害 字 元 四 


Parameters 


Type of keyto generate:- 
人 SSH-1IRSA 团 SSH-2RSA CD SSH-2DSA 


Number of bits in a generasted key- 1024 


兴 不 过 ， 如 果 你 已 经 有 sithub_rsa.pub 这 个 
当 案 的 话 ， 直 接 用 Notepad 开启 这 个 档案 ， 也 
可 以 直接 拿 来 当成 公 鲍 的 内 容 。 


这 个 SSH 公 久 的 内 容 格式 大 致 如 下 : 


SSh-trsa AAAAB3NZzaC1lyc2EAAAABIWAAACEAXLaDP6V 


. 接著 进入 Bitbucket 首页 ， 下 找到 SSH Key 页 
面 ， 芷 按 下 Add Key 以 新 增 金 欠 : 


FF 


View proflle 

Inbox (0) JJ 

Log out (type'g'then 'a') 
Invite a fmend 


lnvite your friends to B6 骨 Create team 
ghve you upto 3 additiol Convertto team 


5 6 的 史 


三 留 Bitbucket Repositories v Create 


Account 嗓 win ~ 


Account settings Account settings 
Groups 

Username 
Noitificaiions 

First name 


Email addresses 


SSH keys Last name 
下 -SA 
Custiom domai Website 


三 名 Bitbucket Repositories ~ Create 


Account 坚 win~ 


Account settings SSH keys 


Sroups Use SSH to avoid password prompts when Yc 


Notifications 
Email addresses 〖 Add key | 


NU 
SSH keys Key 


me There are no keys configured 
Plans and billing 


Intiegrated applications 


4. 输入 一 个 好 记名 称 与 公 鲍 内 容 和 后 ， 就 大 功 告 


成 ， 入 连接 Bitbucket 也 不 用 再 输入 帐 


Add SSH key 


Label Import SSH key from GitHubl 


Key”| ssh-rsa 
AAAAB3NzaC1yc2EAAAABIwAAACEAxtaDp6Vqakim2b2EMJFL99TOApR053qY2n7o 
n8k+prvelmajkjVFqILCu89JJYgz7/VehXxYo11e45iHUC8zkgtzomjuUPVFIGLCKKPk8 
WbmNAINZbOCVnsJI1g9EYM4aMulh9DaJw6N7KfkYo39ZJR4akmACbjdO+ls71cRJ6h 
OkBo2wPRqsOJeipldEh4wiekaWWApZyBm2uUsvs5nb/FtdxZ+AQIODozeLJFmnjBXCJ 
UM4TimbWgZR2tPyvhl4ld5NRQH4112SLiQXPOYN2SXGRRLZGOX7LBLk6FzmdUQBx 
EzayK7t6SBmsHyRvMOOADI55L8oDCjYzghiw== Imported-openssh-key 


Don't have a key yet? 
Read our help docs for creating keys 
Already have a key? 

Copy your key to your cipboard 


三 名 Bitbucket Repositories ~- Create 


Account 时 win- 


Account settings SSH keys 


Groups Use SSHto avoid password prompts when you push code 
Notifications 


dd ke 
Email addresses 


SSH keys Key 


Custom domain Import SSH key from GitHub 
Plans and biling 


S 


如 何 逮 原 一 个 git Febase 继 动 
如 果 单 纯 地 用 sit merge 合 供 一 个 档案 ， 要 还 原 


儒 很 简单 ， 直 接 打 sit reset --hard ORIG_HERAD 
即 可 膛 原 本 次 合 儒 的 变更 。 但 是 sit rebase 怎 诬 
办 ? 因为 git rebase 下 人 线 图 改 释 ， 而 且 分 
支 的 结构 也 会 发 生 释 化 ， 感 凤 上 好 像 很 难 做 还 原 动 
作 ， 但 其 实 非 常 简 单 。 


册 
中 


我 用 一 张 图 来 解释 逮 原 的 过 程 : 


one: from gitegithuhb-com:csswizardryACSS-Guidelines -git 


S 5f34d68 
and updated refs/heads/master- 


HEhRDB《By> : 
HERDG《1y : 
HERDB《2y: 
HEnRDBe《37y: 


- Thanks- 
ag8ac?1926931fhb5346c4egc4hb4cc2d 
HERDB《47 : Bgithup-conm swizardryACSS-GuideIines -9it 


8lc5 


Fanslation- Thanks。@kiwanami 


:NCSS-Guidqelines> 


1. 先知 道 你 在 Rebase 之 前 ， 是 落 於 哪个 版 本 。 

2. 再 查 出 你 要 从 哪个 版 本 开始 Rebase 

3. 然后 真正 执行 Rebase 动作 

4. 不 管 做 了 哪些 动作 ， 你 再 执行 一 
次 git reflog 就 可 以 看 出 Rebase 真正 做 了 
绑 件 事 

5. 各 要 还 原 Rebase 的 版 本 ， 只 要 找到 Rebase 
之 前 的 版 本 ， 就 可 以 透 过 ait reset --hard 
来 还 原 


取得 未 端 储存 麻 的 统计 和 间 读 


由 於 我 们 透 过 sit clone 的 时 候 ， 就 可 以 抓 回 完整 
的 版 本 纪 他 “， 这 代表 我 们 可 以 随时 在 本 地 储存 库 统 
计 啤 本 资讯 。 


例如 我 们 想 取 得 版 本 库 中 所 有 人 的 commit 次 数 统 
计 ， 可 以 输入 sit shortlog -sne 即 可 详细 列 出 
每 个 人 的 commit 次 数 ， 而 且 加 上 -n 参数 晃 可 以 
按照 commit 数量 进行 降 医 排序 : 


G:NXCSS-Guidelines>git short1lodg -sne 
58 。 Harry Robperts <harryQcsswizaradqry.Ccom> 
2 Matteo Nicoletti <matteo.nicolettiewebde: 
1 _ Mike <mikeGmikePennisi.com> 


1 _ Tim Vandecasteele <tim.vandecasteeleagma. 


也 可 以 利用 sit shortlog 显示 出 每 个 人 最 近 
commit 过 的 历史 纪 凶 。 


G:NXCSS-Guidelines>dit short1lod 
HaseyRelbertesaGs Si 

上 E 放 请 上 Gil 

Addindg readme andq other guidqeline 七 ext 
UpdateURDEONBSKYEB 
FiXx t 上 ypo in README 
Upaate aoc URDL 
Update README intro 


Update README Intro 


Embolden sharing qdqetails 


Update copyright qdqate 

Add closing Sentence 七 DO PreprocesSSsor SectLL 
EAISROUSEEHESIGS SS 的 全 放生 二 

性 避 丰 人 人 CE EECOnadaEonal connmenht . 
< 和 EMSo) 

Adadd note about Syntax ules . 

Use more robust URL in 廿 weet 1ink. 

Use more Fobust URL in 七 Weet 工 LnK 

Use more robust URL in 廿 weet 工 LnK 

Merge PulLl1l reduest #3 from juggdLinmike/tyP 
Addq section on key Selectors 

Add section on key Selectors 

Remove Twitter 工 nK 

Reformat andq adqdq BEM Section 


Complete Fewrite 


Rename 工 L1e 

AdaaEtaleeEcoEEeonmeesnies 

Addq note about spaces and multilLline 
Reword of quasi-dqualifieadq selectors 
Reword ruleset anatomy section 

下 有 有 EVDOETO EAIamamoeconwenmienons 
ClLarify BEM meanind 
REEYDomnnEeommenmes 硬 SScteaon 
Gy 全 
TEAEEeEicoEsececonasectnon 

Reword new componnets section 

Addq JS namind Section 


AQaawuSsnookKstoETEoCG 


内 = = Ra 

Rewordq Source order section 

本 GaEe KeOEEnUNWER SS Sales 旦 gd 

Addq classes in HIML section 

Remove Sky qisclaimeL 

Personalise tone of Voice 

ANAaedESsscEnon 本 1 玫 本 世 E 站 有 SEONaUais aiENGON 

Add 1Link to Russian trzranslation by hnatmuc 


Remove unnecessary word 


S1Light zeword 


CompletelLly reVerse Stance on international 
Merde branch 'master' of 9ithub.com:csswiz， 
要 二 人 RS QQSEaDEe7 

下 二 文风 DIEKESTQSE SECD) 

Addq Chinese translLation 
aaaankKEeeokaenchesans 下 二 EROi 


Merge PulL1l reduest #7 from matteo-webdqev/m 


Merdge Pul1l request 井 15 from 七 Im-Vandqecaste 


Add Link to JUapanese translLation.。. IThanksyv 
Matteo Nicoletti (2) : 
Removed trailing spaces 


Correctedq "inulit.css's table gridq Systemy" 


Me 人 本 瑟 


Insert omitted word 


Tim Vanadqecasteele (1) : 


NOISE 三光 和 


你 也 可 以 利用 GitHub 上 Graph 页 面 提供 的 统计 资 
训 过 


《> Code 
0 release 4 contribut 


人 Issues 


dvice and soon 


届 


这 壬 主要 提供 六 种 报表 : 


。 Contributors (本 专案 贡献 者 的 活 趴 程度 ) 

。Commit Activity (每 一 天 的 commit 活动 数量 ) 

。Code Fredquency (原始 码 暴 动 服 务 ， 可 看 出 每 
天 新 增 与 删除 的 程式 码 行 数 ) 

。 Punchcard (每 一 天 的 commit 数量 ， 用 打卡 的 
方式 来 显示 ) (类 似 上 下 班 打卡 的 那 种 卡片 ) 

。 Network (pull request 且 merge 的 图 形 表 示 ) 

Members (所 有 fork 此 专案 的 github 成 遇 ) 


进 去 之 人 后， 还 可 以 继续 往 下 错 (Drill-Down)， 查 看 
更 细 的 统计 报表 : 


csswWizardry / CSS-Guidelines 赵 Watch ~ 240 但 Star 2706 时 Fork 420 


好 


从 工作 目录 靖 除 不 在 版 本 库 中 的 榴 案 
我 们 在 Git 工作 目 朱 中 ， 通 常会 产生 一 些 不 必要 的 


档案 7 而 这 些 档 案 通常 都 会 透 过 .9itignore 档 
案 ， 让 Git 自动 忽略 这 些 档案 。 如 果 你 今天 想 要 把 
这 些 额 外 的 档案 都 给 删除 把 ， 可 以 透 


9it Clean 一 工 强迫 删除 这 些 档案 。 


涡 六 测 


不 过 ， 执行 之 前 逮 是 建议 用 glit Clean 一 nn 看 一 
下 ， 这 个 指令 会 列 出 他 预计, 会 删除 那些 档案 ， 
等 你 确认 过 和 后 在 执行 sit clean -E 删除 即 可 档 


如 果 你 将 “本 地 分 支 , 透 

过 ait push _ origin FixForcRLE 指令 建立 起 上 趟 
端 分 支 ， ， 也 代表 在 踪 端 会 被 建立 一 个 名 

入 FixForCRLF 的 分 文 ， 如 果 你 想 在 本 地 下 指令 删 
除 乏 端 追 跳 分 文 ， 可 以 输入 以 下 指令 (在 舟 端 分 文 

前 面 加 上 个 : 而 已 ) : 


GE 本 忆 USh 本 OgameFROSROCRTIR 


另 一 个 同样 目的 的 指令 用 法 如 下 ， 指 令 看 起 来 较 篇 


直 攻 些 : 


OnSE 汪 折 焉 s 几 本 Ceaim 本 三 三 避 人 二 世 S 汪 贡 下 区 下 所 于 人 R 民 市 下 


兴 不 过 使 用 时 要 注意 ， 如 果 有 人 下 载 过 过 个 踪 端 分 
支 的话 ， 他 就 再 也 无 法 透 过 sit push 把 变更 推送 
上 来 了 。 

找 出 改 坏 程式 的 儿 手 

蔡 原始 码 做 版 控 ， 最 有 效 的 就 是 每 个 档案 的 每 一 行 


都 可 以 进行 详细 追 跳 ， 今 天 如 果 程 式 发 生 典 常 ， 且 
找到 哪 一 行 出 铺 时 ， 就 可 以 适 过 sit blame 指令 ， 
帮 你 找 出 真正 改 壤 程 式 的 铝 手 ， 芷 且 去 看 他 为 什么 


会 改 坏 。 


用 法 如 下 : 


9it blame [filename] 


git blame -LI [开始 行 数 ] ，[ 结 束 行 数 ] [fiLlename] 


例如 : 


9it blame README .md 


9it blame -LI 8,16 ViewModqe1ls/MemberViewMoade1l .cs 


djit blame -L 4，Moadqels/Prodquct .cs 


今日 小 给 


一 些小 技巧 ， 需 要 的 时 候 就 会 用 的 到 。 


铁人 赛 完 结 感言 


短 短 30 天 ， 说 长 不 长 、 褒 短 不 短 ， 但 我 为 了 写 这 
仙 系 列 文 章 ， 还 真 的 是 么 翻 了 。 刚 我 把 我 的 文章 原 
稿 放 进 Word 统计 ， 这 才 往 觉 我 写 了 十 继 万 字 (不 含 
程式 码 )， 这 真是 大 神奇 了 ， 像 克 ! 


页 六 

字 坟 

字 元 数 (不 合 空 白 ) 
字 元 数 ( 合 空 白 ) 
段落 雪 


行 雪 


半 形 字 


言 文字 方志 、 计 膨 及 章节 附 主 (D 


如 同 我 之 前 讲 过 的 ， 内 然 市 面 上 Git 的 GUI 工具 好 
做 套 ， 但 想 要 有 效率 且 正 确 的 使 用 这 些 Git 工具 ， 

先 建立 起 完整 的 Git 基本 观念 非常 重要 ， 否 则 只 会 
一 直 鬼 打 棋 而 已 。 


Git 博大 精深 , 短 短 30 天 著 实 无 法 完整 交代 所 有 细 
和 节 ， 但 工作 上 会 用 到 的 观念 与 工具 都 讲 到 ， 如 果 认 


真 看 的 话 ， 相 信 针 大 家 在 工作 上 会 用 助 。 


。 HOME 

。 回 目 销 

。 前 一 天 : 如 何 将 Subversion 专案 汇 入 到 Git 储 
存 库 


